标签:标准输入 span 修改 输入 pre root 分组 linux 字符
原文: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就打印此行。
标签:标准输入 span 修改 输入 pre root 分组 linux 字符
原文地址:http://www.cnblogs.com/zy516563199/p/7912008.html