Linux下的sed流编辑器命令详解

 一、命令示例

[root@master rh]# cat test.txt 
this is first line
this is second line
this is third line
this is fourth line
this fifth line
happy everyday
end

1. a命令

sed '1a \add one' test.txt

本例命令部分中的1表示第一行,同样的第二行写成2,第一行到第三行写成1,3,用$表示最后一行,比如2,$表示第二行到最后一行中间所有的行(包含第二行和最后一行)。本例的作用是在第一行之后增加字符串”add one”,从输出可以看到具体效果。

sed '1,$a \add one' test.txt

本例表示在第一行和最后一行所有的行后面都加上”add one”字符串,从输出可以看到效果。

sed '/first/a \add one' test.txt

本例表示在包含”first”字符串的行的后面加上字符串”add one”,从输出可以看到第一行包含first,所以第一行之后增加了”add one”

sed '/^ha.*day$/a \add one' test.txt

本例使用正则表达式匹配行,^ha.*day$表示以ha开头,以day结尾的行,则可以匹配到文件的”happy everyday”这样,所以在该行后面增加了”add one”字符串。

 

2. i命令
i命令使用方法和a命令一样的,只不过是在匹配的行的前面插入字符串,所以直接将上面a命令的示例的a替换成i即可。

 

3. c命令

sed '$c \add one' test.txt

本例表示将最后一行替换成字符串”add one”,从输出可以看到效果。

sed '4,$c \add one' test.txt

本例将第四行到最后一行的内容替换成字符串”add one”。

sed '/^ha.*day$/c \replace line' test.txt

 

4. d命令

sed '/^ha.*day$/d' test.txt

本例删除以ha开头,以day结尾的行。

sed -e '/abc/d' a.txt > a.log

删除a.txt中含"abc"的行,将操作之后的结果保存到a.log

 

5. p命令

sed -n '4,$p' test.txt

本例在屏幕上打印第四行到最后一行的内容,p命令一般和-n选项一起使用。

sed -n '/^ha.*day$/p' test.txt

本例打印以ha开始,以day结尾的行。

 

6. s命令
实际运用中s命令式最常使用到的。

sed 's/line/text/g' test.txt

本例将文件中的所有line替换成text,最后的g是global的意思,也就是全局替换,如果不加g,则只会替换本行的第一个line。

sed '/^ha.*day$/s/happy/very happy/g' test.txt

本例首先匹配以ha开始,以day结尾的行,本例中匹配到的行是”happy everyday”这样,然后再将该行中的happy替换成very happy。

sed 's/\(.*\)line$/\1/g' test.txt

这个例子有点复杂,先分解一下。首先s命令的模式是s/old/new/g这样的,所以本例的old部分即\(.*\)line$,sed命令中使用\(\)包裹的内容表示正则表达式的第n部分,序号从1开始计算,本例中只有一个\(\)所以\(.*\)表示正则表达式的第一部分,这部分匹配任意字符串,所以\(.*\)line$匹配的就是以line结尾的任何行。然后将匹配到的行替换成正则表达式的第一部分(本例中相当于删除line部分),使用\1表示匹配到的第一部分,同样\2表示第二部分,\3表示第三部分,可以依次这样引用。比如下面的例子:

sed 's/\(.*\)is\(.*\)line/\1\2/g' test.txt

正则表达式中is两边的部分可以用\1和\2表示,该例子的作用其实就是删除中间部分的is。

 

二、补充

1. 提取指定的行

sed -n '2p' tmp.txt > a.txt  #只提取第2行
sed -n '2,7p' tmp.txt > a.txt #提取第2-7行
sed -n '2p;7p' tmp.txt > a.txt #提取第2行和第7行
sed -n '1~2p' tmp.txt > a.txt #提取奇数行
sed -n '2~2p' tmp.txt > a.txt #提取偶数行
sed -n '3~3p' tmp.txt > a.txt #提取3的倍数行
sed -n '/2/p' tmp.txt > a.txt #提取匹配2的行,2 12 20 21 22 ...
sed -n '/2/!p' tmp.txt > a.txt #提取不匹配2的行,1 3 4 ...
sed -n '/2\|5/p' tmp.txt > a.txt #提取同时满足2和5的行,2 5 12 15 20 21 ...
sed -n '/^2/p' tmp.txt > a.txt #提取以2开头的行,2 20 21 ...
sed -n '/2$/p' tmp.txt > a.txt #提取以2结尾的行,2 20 21 ...
sed -n '/^2\|^5/p' tmp.txt > a.txt #提取以2和5开头的行,2 5 20 21 ...
sed -n '3~3!p' tmp.txt > a.txt #提取3的倍数以外的行 1 2 4 5 7 ...

2. 删除指定的行

sed -i '/bc/d' sed_test.txt //-i表示在源文件上生效
sed -i '/bb=1/d' sed_test.txt //bb=12 和 bb=18 都删除了

sed '/^ab/d' sed_test.txt //删除以字符串ab开头的行
sed '/ab$/d' sed_test.txt //删除以字符串ab结尾的行,但是不成功!

3. 替换

sed 's/^b/mm/g' sed_test.txt //找到以b字符串开头的行,并将b字符替换为mm字符串。-g表示全局替换,但实测有无g无影响
sed 's/^b.*/mm/g' sed_test.txt //找到以b字符串开头的行,并将整行替换为mm字符串

 

 

 

 

请参考:http://man.linuxde.net/sed

posted on 2017-12-19 23:29  Hello-World3  阅读(218)  评论(0编辑  收藏  举报

导航