Linux学习笔记2(sed命令)

时间:2021-10-15 15:31:30

原文:http://blog.oldboyedu.com/commands-sed/

语法格式

sed [options] [sed-commands] [input-file]
sed [选项] [sed命令] [输入文件]
说明:
1. 注意sed和后面的选项之间至少有一个空格。
2. 为了避免混淆,本文称呼sed为sed软件。sed-commands(sed命令)是sed软件内置的一些命令选项,为了和前面的options(选项)区分,故称为sed命令。
3. sed-commands既可以是单个sed命令,也可以是多个sed命令组合。
4. input-file(输入文件)是可选项,sed还能够从标准输入如管道获取输入。

基本操作

实例使用文本:
[root@oldboy
~]# cat person.txt
101,oldboy,CEO
102,zhangyao,CTO
103,Alex,COO
104,yy,CFO
105,feixue,CIO

a 追加文本到指定行后

i 插入文本到指定行前

[root@oldboy ~]# sed '2a 106,dandan,CSO' person.txt
101,oldboy,CEO
102,zhangyao,CTO
106,dandan,CSO
103,Alex,COO
104,yy,CFO
105,feixue,CIO
[root@oldboy
~]# sed '2i 106,dandan,CSO' person.txt
101,oldboy,CEO
106,dandan,CSO
102,zhangyao,CTO
103,Alex,COO
104,yy,CFO
105,feixue,CIO

多行增加

[root@oldboy ~]# sed '2a 106,dandan,CSO\n107,bingbing,CCO' person.txt
101,oldboy,CEO
102,zhangyao,CTO
106,dandan,CSO #→第1种写法
107,bingbing,CCO
103,Alex,COO
104,yy,CFO
105,feixue,CIO
[root@oldboy
~]# sed '2a 106,dandan,CSO \
> 107,bingbing,CCO' person.txt
101,oldboy,CEO
102,zhangyao,CTO
106,dandan,CSO #→第2种写法
107,bingbing,CCO
103,Alex,COO
104,yy,CFO
105,feixue,CIO
#→sed命令i的使用方法是一样的,因此不再列出。

指定执行的地址范围

sed软件可以对单行或多行进行处理。如果在sed命令前面不指定地址范围,那么默认会匹配所有行。
用法:n1[,n2]{sed
-commands}
地址用逗号分隔的,n1,n2可以用数字、正则表达式、或二者的组合表示。
例子:
   
10{sed-commands} 对第10行操作
   
10,20{sed-commands} 对10到20行操作,包括第10,20行
   
10,+20{sed-commands} 对10到30(10+20)行操作,包括第10,30行
   
1~2{sed-commands} 对1,3,5,7,……行操作
   
10,${sed-commands} 对10到最后一行($代表最后一行)操作,包括第10行
/oldboy/{sed-commands} 对匹配oldboy的行操作
/oldboy/,/Alex/{sed-commands} 对匹配oldboy的行到匹配Alex的行操作
/oldboy/,${sed-commands} 对匹配oldboy的行到最后一行操作
/oldboy/,10{sed-commands} 对匹配oldboy的行到第10行操作,注意:如果前10行没有匹配到oldboy,sed软件会显示10行以后的匹配oldboy的行,如果有。
1,/Alex/{sed-commands} 对第1行到匹配Alex的行操作
/oldboy/,+2{sed-commands} 对匹配oldboy的行到其后的2行操作

d 删除指定的行

[root@oldboy ~]# sed 'd' person.txt
[root@oldboy
~]#
[root@oldboy
~]# sed '2d' person.txt
101,oldboy,CEO
103,Alex,COO
104,yy,CFO
105,feixue,CIO
[root@oldboy
~]# sed '2,5d' person.txt
101,oldboy,CEO
[root@oldboy
~]# sed '3,$d' person.txt
101,oldboy,CEO
102,zhangyao,CTO
[root@oldboy
~]# sed '1~2d' person.txt
102,zhangyao,CTO
104,yy,CFO
[root@oldboy
~]# sed '1,+2d' person.txt
104,yy,CFO
105,feixue,CIO
[root@oldboy
~]# sed '/zhangyao/d' person.txt
101,oldboy,CEO
103,Alex,COO
104,yy,CFO
105,feixue,CIO
[root@oldboy
~]# sed '/oldboy/,/Alex/d' person.txt
104,yy,CFO
105,feixue,CIO
[root@oldboy
~]# sed '/oldboy/,3d' person.txt
104,yy,CFO
105,feixue,CIO

按行替换:

c 用新行取代旧行

[root@oldboy ~]# sed '2c 106,dandan,CSO' person.txt
101,oldboy,CEO
106,dandan,CSO
103,Alex,COO
104,yy,CFO
105,feixue,CIO

文本替换:

s:单独使用→将每一行中第一处匹配的字符串进行替换 ==>sed命令 
g:每一行进行全部替换 ==>sed命令s的替换标志之一,非sed命令 
-i:修改文件内容 ==>sed软件的选项

[root@oldboy ~]# sed 's#zhangyao#oldboyedu#g' person.txt
101,oldboy,CEO
102,oldboyedu,CTO
103,Alex,COO
104,yy,CFO
105,feixue,CIO
[root@oldboy
~]# cat person.txt
101,oldboy,CEO
102,zhangyao,CTO
103,Alex,COO
104,yy,CFO
105,feixue,CIO
[root@oldboy
~]# sed -i 's#zhangyao#BBB#g' person.txt
[root@oldboy
~]# cat person.txt
101,oldboy,CEO
102,BBB,CTO
103,Alex,COO
104,yy,CFO
105,feixue,CIO

变量替换:

[root@oldboy ~]# cat test.txt #→再新建一个文本
a
b
a
[root@oldboy
~]# x=a
[root@oldboy
~]# y=b
[root@oldboy
~]# echo $x $y
a b
[root@oldboy
~]# sed s#$x#$y#g test.txt
b
b
b
[root@oldboy
~]# sed 's#$x#$y#g' test.txt
a
b
a
[root@oldboy
~]# sed 's#'$x'#'$y'#g' test.txt
b
b
b
[root@oldboy
~]# sed "s#$x#$y#g" test.txt
b
b
b
[root@oldboy
~]# eval sed 's#$x#$y#g' test.txt
b
b
b

分组替换:

[root@oldboy ~]# echo I am oldboy teacher. |sed 's#^.*am \([a-z].*\) tea.*$#\1#g'
oldboy
[root@oldboy
~]# echo I am oldboy teacher. |sed -r 's#^.*am ([a-z].*) tea.*$#\1#g'
oldboy
[root@oldboy
~]# echo I am oldboy teacher. |sed -r 's#I (.*) (.*) teacher.#\1\2#g'
amoldboy

oldboy字符替换I am oldboy teacher.

特殊符号&代表被替换的内容

[root@oldboy ~]# sed '1,3s#C#--&--#g' person.txt #→此处&等于C
101,oldboy,--C--EO #→将1到3行的C替换为--C--
102,zhangyao,--C--TO
103,yy,--C--OO
104,feixue,CFO
105,dandan,CIO

p 输出指定内容,但默认会输出2次匹配的结果,因此使用n取消默认输出

[root@oldboy ~]# sed '2p' person.txt
101,oldboy,CEO
102,zhangyao,CTO
102,zhangyao,CTO
103,Alex,COO
104,yy,CFO
105,feixue,CIO
[root@oldboy
~]# sed -n '2p' person.txt
102,zhangyao,CTO
[root@oldboy
~]# sed -n '2,3p' person.txt
102,zhangyao,CTO
103,Alex,COO
说明:取行就用sed,最简单
[root@oldboy
~]# sed -n '1~2p' person.txt
101,oldboy,CEO
103,Alex,COO
105,feixue,CIO
[root@oldboy
~]# sed -n 'p' person.txt
101,oldboy,CEO
102,zhangyao,CTO
103,yy,COO
104,feixue,CFO
105,dandan,CIO

按字符串查找

[root@oldboy ~]# sed -n '/CTO/p' person.txt
102,zhangyao,CTO
[root@oldboy
~]# sed -n '/CTO/,/CFO/p' person.txt
102,zhangyao,CTO
103,Alex,COO
104,yy,CFO
[root@oldboy ~]# sed -n '2,/CFO/p' person.txt
102,zhangyao,CTO
103,Alex,COO
104,yy,CFO
[root@oldboy
~]# sed -n '/feixue/,2p' person.txt
105,feixue,CIO
#→特殊情况,前两行没有匹配到feixue,就向后匹配,如果匹配到feixue就打印此行。