
抛砖引玉
预览:
sed -n -e '/aaa/{nnns|$|\n新添加的行|p}' 3hang_addline.txt应用:
sed -i -e '/aaa/{nnns|$|\n新添加的行|}' 3hang_addline.txt解释:
nnn就是从匹配的aaa往下走三行,到位后,将行尾添加换行符——新增一行,\n后面就是新行的内容。
你的提问只需要两个n,即往下走两行,再添加新行,就行了。我审题不严。
可能你要问,如果我要在匹配到aaa后的1000行添加新行,难道要打1000次“n”吗?
我的回答是,如果数字很大,我到宁愿用你提问中不想用的那个方法。
预览:
num=`sed -n -e '/aaa/=' 3hang_addline.txt`sed -n $((num+3))'s|$|\n你要添加的行|p' 3hang_addline.txt应用:
num=`sed -n -e '/aaa/=' 3hang_addline.txt`sed -i $((num+3))'s|$|\n你要添加的行|' 3hang_addline.txt sed 是 stream editor 的缩写,流编辑器,主要用于对标准输出或文件进行逐行处理。
原文件test_sed.sh内容:
在testfile文件的第四行后添加一行,并将结果输出到标准输出,在命令行提示符下输入如下命令:
a 动作是在匹配的行之后追加字符串,追加的字符串中可以包含换行符(实现追加多行的情况)
追加一行的话前后都不需要添加换行符 \n
追加多行
同理,指定行前插入内容
打印第3-4行
将第二行内容修改为111
搜索有root关键字的行
匹配有连续5位数字的行
或者
最后还是想用简单的脚本解决,发现使用 sed 命令可以方便得在文件每一行后添加一个字符。首先看一下 sed 命令。
sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间” (pattern space) ,接着用 sed 命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。 Sed 主要用来自动编辑一个或多个文件;简化对文件的反复 *** 作;编写转换程序等。
假设处理的文本为 test.file ,在每行的头添加字符,比如 HEAD ,命令如下:
在每行的行尾添加字符,比如 TAIL ,命令如下:
几点说明:
这样就处理完了!总之恰当使用sed命令是可以避免来回打开文件造成的时间浪费,可以使用sed命令在linux脚本中做一些更好玩的事情。希望这篇文章可以给你一些帮助~
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)