标签:资料
sed 的基本语法为
sed [options] [sed-commands] [input-file]
sed [选项] [sed命令] [输入文件]
选项分别为:
-n∶使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN的资料一般都会被列出到萤幕上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
-e∶直接在指令列模式上进行 sed 的动作编辑;
-f∶直接将 sed 的动作写在一个档案内, -f filename 则可以执行 filename 内的sed 动作;
-r∶sed 的动作支援的是延伸型正规表示法的语法。(预设是基础正规表示法语法)
-i∶直接修改读取的档案内容,而不是由萤幕输出。
sed命令为:
a ∶新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
c ∶取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
d ∶删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
i ∶插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
p ∶列印,亦即将某个选择的资料印出。通常 p 会与参数 sed -n 一起运作~
s ∶取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!
使用方法如下:
# 创建包含下面内容的文件,后面的操作都会使用这个文件。[root@oldboy ~]# cat person.txt101,oldboy,CEO102,zhangyao,CTO103,Alex,COO104,yy,CFO105,feixue,CIO
a 追加文本到指定行后
i 插入文本到指定行前
[root@oldboy ~]# sed ‘2a 106,dandan,CSO‘ person.txt101,oldboy,CEO102,zhangyao,CTO106,dandan,CSO103,Alex,COO104,yy,CFO105,feixue,CIO[root@oldboy ~]# sed ‘2i 106,dandan,CSO‘ person.txt101,oldboy,CEO106,dandan,CSO102,zhangyao,CTO103,Alex,COO104,yy,CFO105,feixue,CIO
[root@oldboy ~]# sed ‘2a 106,dandan,CSO\n107,bingbing,CCO‘ person.txt101,oldboy,CEO102,zhangyao,CTO106,dandan,CSO #→第1种写法107,bingbing,CCO103,Alex,COO104,yy,CFO105,feixue,CIO[root@oldboy ~]# sed ‘2a 106,dandan,CSO \> 107,bingbing,CCO‘ person.txt101,oldboy,CEO102,zhangyao,CTO106,dandan,CSO #→第2种写法107,bingbing,CCO103,Alex,COO104,yy,CFO105,feixue,CIO#→sed命令i的使用方法是一样的,因此不再列出。
在我们学习系统优化时,有一个优化点:更改ssh服务远程登录的配置。主要的操作是在ssh的配置文件加入下面5行文本。(下面参数的具体含义见其他课程。)
Port 52113PermitRootLogin noPermitEmptyPasswords noUseDNS noGSSAPIAuthentication no
我们可以使用vi命令编辑这个文本,但这样就比较麻烦,现在想一条命令增加5行文本到第13行前?
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.txt101,oldboy,CEO103,Alex,COO104,yy,CFO105,feixue,CIO[root@oldboy ~]# sed ‘2,5d‘ person.txt101,oldboy,CEO[root@oldboy ~]# sed ‘3,$d‘ person.txt101,oldboy,CEO102,zhangyao,CTO[root@oldboy ~]# sed ‘1~2d‘ person.txt102,zhangyao,CTO104,yy,CFO[root@oldboy ~]# sed ‘1,+2d‘ person.txt104,yy,CFO105,feixue,CIO[root@oldboy ~]# sed ‘/zhangyao/d‘ person.txt101,oldboy,CEO103,Alex,COO104,yy,CFO105,feixue,CIO[root@oldboy ~]# sed ‘/oldboy/,/Alex/d‘ person.txt104,yy,CFO105,feixue,CIO[root@oldboy ~]# sed ‘/oldboy/,3d‘ person.txt104,yy,CFO105,feixue,CIO
[root@oldboy ~]# sed ‘/oldboy/d‘ person.txt #→删除包含"oldboy"的行102,zhangyao,CTO103,Alex,COO104,yy,CFO105,feixue,CIO
c 用新行取代旧行
[root@oldboy ~]# sed ‘2c 106,dandan,CSO‘ person.txt101,oldboy,CEO106,dandan,CSO103,Alex,COO104,yy,CFO105,feixue,CIO
s:单独使用→将每一行中第一处匹配的字符串进行替换 ==>sed命令
g:每一行进行全部替换 ==>sed命令s的替换标志之一,非sed命令
-i:修改文件内容 ==>sed软件的选项
sed软件替换模型(方框▇被替换成三角▲)
sed -i ‘s/▇/▲/g‘ oldboy.log
sed -i ‘s#▇#▲#g‘ oldboy.log
观察特点
两边是引号,引号里面的两边分别为s
和g
,中间是三个一样的字符/
或#
作为定界符。#
能在替换内容包含/
有助于区别。定界符可以是任意符号如:
或|
等,但当替换内容包含定界符时,需转义即:
|
。经过长期实践,建议大家使用#
作为定界符。
定界符/
或#
,第一个和第二个之间的就是被替换的内容,第二个和第三个之间的就是替换后的内容。
s#▇#▲#g
,▇能用正则表达式,但▲不能用,必须是具体的。
默认sed软件是对模式空间(内存中的数据)操作,而-i选项会更改磁盘上的文件内容。
[root@oldboy ~]# sed ‘s#zhangyao#oldboyedu#g‘ person.txt101,oldboy,CEO102,oldboyedu,CTO103,Alex,COO104,yy,CFO105,feixue,CIO[root@oldboy ~]# cat person.txt101,oldboy,CEO102,zhangyao,CTO103,Alex,COO104,yy,CFO105,feixue,CIO[root@oldboy ~]# sed -i ‘s#zhangyao#BBB#g‘ person.txt[root@oldboy ~]# cat person.txt101,oldboy,CEO102,BBB,CTO103,Alex,COO104,yy,CFO105,feixue,CIO[root@oldboy ~]# sed -i ‘s#oldboyedu#zhangyao#g‘ person.txt #→还原测试文件
指定行精确修改配置文件,这样可以防止修改多了地方。
[root@oldboy ~]# sed ‘3s#0#9#‘ person.txt101,oldboy,CEO102,zhangyao,CTO193,Alex,COO104,yy,CFO105,feixue,CIO
[root@oldboy ~]# cat test.txt #→再新建一个文本aba[root@oldboy ~]# x=a[root@oldboy ~]# y=b[root@oldboy ~]# echo $x $ya b[root@oldboy ~]# sed s#$x#$y#g test.txtbbb[root@oldboy ~]# sed ‘s#$x#$y#g‘ test.txtaba[root@oldboy ~]# sed ‘s#‘$x‘#‘$y‘#g‘ test.txtbbb[root@oldboy ~]# sed "s#$x#$y#g" test.txtbbb[root@oldboy ~]# eval sed ‘s#$x#$y#g‘ test.txtbbb
\( \)
和\1
的使用说明sed软件的\( \)
的功能可以记住正则表达式的一部分,其中,\1
为第一个记住的模式即第一个小括号中的匹配内容,\2
第二记住的模式,即第二个小括号中的匹配内容,sed最多可以记住9个。
例:echo I am oldboy teacher.
如果想保留这一行的单词oldboy,删除剩下的部分,使用圆括号标记想保留的部分。
[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.
下面解释用□
代替空格
^.*am□
–>这句的意思是以任意字符开头到am□
为止,匹配文件中的I am□
字符串;
\([a-z].*\)□
–>这句的外壳就是括号\(\)
,里面的[a-z]
表示匹配26个字母的任何一个,[a-z].*
合起来就是匹配任意多个字符,本题来说就是匹配oldboy
字符串,由于oldboy
字符串是需要保留的,因此用括号括起来匹配,后面通过\1
来取oldboy
字符串。
□tea.*$
–>表示以空格tea
起始,任意字符结尾,实际就是匹配oldboy
字符串后,紧接着的字符串□teacher.
;
后面被替换的内容中的\1
就是取前面的括号里的内容了,也就是我们要的oldboy
字符串。
()
是扩展正则表达式的元字符,sed软件默认识别基本正则表达式,想要使用扩展正则需要使用\
转义,即\(\)
。sed使用-r
选项则可以识别扩展正则表达式,此时使用\(\)
反而会出错。
[root@oldboy ~]# chkconfig --list|grep "3:on"|grep -vE "sshd|crond|network|rsyslog|sysstat"|awk ‘{print $1}‘|sed -r ‘s#^(.*)#chkconfig \1 off#g‘|bash[root@oldboy ~]# chkconfig --list|grep "3:on"crond 0:off 1:off 2:on 3:on 4:on 5:on 6:offnetwork 0:off 1:off 2:on 3:on 4:on 5:on 6:offrsyslog 0:off 1:off 2:on 3:on 4:on 5:on 6:offsshd 0:off 1:off 2:on 3:on 4:on 5:on 6:offsysstat 0:off 1:on 2:on 3:on 4:on 5:on 6:off
&
代表被替换的内容[root@oldboy ~]# sed ‘1,3s#C#--&--#g‘ person.txt #→此处&等于C101,oldboy,--C--EO #→将1到3行的C替换为--C--102,zhangyao,--C--TO103,yy,--C--OO104,feixue,CFO105,dandan,CIO
当前目录下有文件如下所示:
[root@oldboy test]# lsstu_102999_1_finished.jpg stu_102999_2_finished.jpg stu_102999_3_finished.jpg stu_102999_4_finished.jpg stu_102999_5_finished.jpg
要求用sed命令重命名,效果为stu_102999_1_finished.jpg==>stu_102999_1.jpg
,即删除文件名的_finished
p 输出指定内容,但默认会输出2次匹配的结果,因此使用n取消默认输出
[root@oldboy ~]# sed ‘2p‘ person.txt101,oldboy,CEO102,zhangyao,CTO102,zhangyao,CTO103,Alex,COO104,yy,CFO105,feixue,CIO[root@oldboy ~]# sed -n ‘2p‘ person.txt102,zhangyao,CTO[root@oldboy ~]# sed -n ‘2,3p‘ person.txt102,zhangyao,CTO103,Alex,COO说明:取行就用sed,最简单[root@oldboy ~]# sed -n ‘1~2p‘ person.txt101,oldboy,CEO103,Alex,COO105,feixue,CIO[root@oldboy ~]# sed -n ‘p‘ person.txt101,oldboy,CEO102,zhangyao,CTO103,yy,COO104,feixue,CFO105,dandan,CIO
[root@oldboy ~]# sed -n ‘/CTO/p‘ person.txt102,zhangyao,CTO[root@oldboy ~]# sed -n ‘/CTO/,/CFO/p‘ person.txt102,zhangyao,CTO103,Alex,COO104,yy,CFO
[root@oldboy ~]# sed -n ‘2,/CFO/p‘ person.txt102,zhangyao,CTO103,Alex,COO104,yy,CFO[root@oldboy ~]# sed -n ‘/feixue/,2p‘ person.txt105,feixue,CIO#→特殊情况,前两行没有匹配到feixue,就向后匹配,如果匹配到feixue就打印此行。
标签:资料
原文地址:http://1979431.blog.51cto.com/1969431/1825701