sed 匹配出多行时如何只在第一个匹配行下方添加行

sed 匹配出多行时如何只在第一个匹配行下方添加行,第1张

可以做到: 只在第一次匹配到alex的行下加新行: root@alex:/tmp# cat alex.txt alex 1 bbbb cccc alex 2 dddd alex 3 root@alex:/tmp# sed '/alex/{s/$/\nI am the new line/:fnb f}' alex.txt alex 1 I am the new line bbbb cccc alex 2 dddd alex 3 root@alex:/tmp#

1:指定行数和列数,比如3行3列插入abc,或2行6列插入AAA,如下所示:

2:符合正则表达式的行,里面的第几列中插入内容:将上面的3s、2s改为/正则表达式/s,例如:

3:某行中,某个/些单词的后面或前面插入字符:

其他混合定位也类似,基本思路是用s替换,首先将位置放到捕获里面(小括号里面),后面用\1引用搜索到的内容,可以在\1后面或前面,或前后增加新的内容,就实现了“插入”功能

最后还是想用简单的脚本解决,发现使用 sed 命令可以方便得在文件每一行后添加一个字符。首先看一下 sed 命令。

sed 是一种在线编辑器,它一次处理一行内容。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间” (pattern space) ,接着用 sed 命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。 Sed 主要用来自动编辑一个或多个文件;简化对文件的反复 *** 作;编写转换程序等。

假设处理的文本为 test.file ,在每行的头添加字符,比如 HEAD ,命令如下:

在每行的行尾添加字符,比如 TAIL ,命令如下:

几点说明:

这样就处理完了!总之恰当使用sed命令是可以避免来回打开文件造成的时间浪费,可以使用sed命令在linux脚本中做一些更好玩的事情。希望这篇文章可以给你一些帮助~


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/bake/11750446.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-18
下一篇2023-05-18

发表评论

登录后才能评论

评论列表(0条)

    保存