1. 语法
1.1 基本语法
# sed [参数] “命令” 文件名
注意:sed是否找到,退出状态都为0,但语法错误除外。
1.2 支持正则
用法:写在 /正则/
之间
1)基本:^, $, ., *, [], [^], < >,(),{}
2)扩展:?, +, { }, |, ( )
扩展正则使用时要加 -r
2. sed 命令
2.1 插入
2.1.1 a
在当前行后插入一行
示例
- 原文件 1.txt 内容如下:
1
2
3
4
5
- 在第3行后插入kkk
# sed "3akkk" 1.txt
- 结果:
1
2
3
kkk
4
5
2.1.2 i
在当前行前插入一行
示例
# sed "3ikkk" 1.txt
2.1.3 r
从文件中读取
示例
- 文件2.txt 内容如下
hello boy
- 在1.txt文件的 2到4行后插入2.txt的内容
# sed "2,4r2.txt" 1.txt
结果如下
1
2
hello boy
3
hello boy
4
hello boy
5
2.1.4 w
将行写入新文件
示例:
- 原文件good.txt内容
111111
222222
333333
4good4
555555
66good
777777
- 逐行扫描good.txt,每遇见good即把该行写入ok.txt
# sed "/good/wok.txt" good.txt
- ok.txt文件写入内容如下:
4good4
66good
2.2 替换
2.2.1 c
整行替换
示例:
将1.txt文件的2、3行一起替换为kkk
# sed "2,3ckkkkk" 1.txt
1
kkk
4
5
2.2.2 s
替换字串
-
语法
sed "s/旧/新/标识" 文件名
标识说明:
g
表示全部替换# sed "s/111/aaa/g" 文件名
1
表示替换查到的第一个(不写默认替换第一个)# sed "s/111/aaa/" 文件名
2
表示查到的第二个# sed "s/111/aaa/2" 文件名
-
示例
将good.txt中的good替换为hello
# sed "s/good/hello/" good.txt
111111
222222
333333
4hello4
555555
66hello
777777
2.3 d
删除行
示例:
删除1.txt第3行
# sed "3d" 1.txt
1
2
4
5
2.4 其他
2.4.1 l
列出非打印字符
列出非打印字符,如行尾$
示例:
# sed -n "l" 1.txt
1$
2$
3$
4$
5$
说明: -n 静默,见选项
2.4.2 p
打印
示例
# sed -n "" 1.txt
# sed -n "p" 1.txt
1
2
3
4
5
说明:-n 静默没有输出,加上p再次被输出
2.4.3 n
读入下一行
因此n后边的命令将不被本行执行
- 示例1
3.txt 文件内容如下:
#1
#2
#3
#4
#5
隔行插入#
# sed '/#/{n;s/^/#/}' 1.txt
输出如下
#1
##2
#3
##4
#5
说明:
处理第一行,读到#
,执行{n;s/^/#/}
,即:n
读取第二行,给第二行行首加#
处理第三行,读到#
,执行{n;s/^/#/}
:n
读取第四行,给第四行行首加#
……
- 示例2
# sed '/3/n;ckkk' 1.txt
输出如下
kkk
kkk
3
kkk
kkk
说明
没到3的时候执行后边的ckkk,整行被替换成kkk
而到3的时候执行了n,即读入下一行,之后有执行ckkk
因此3没有被替换
-
示例3
打印基数行
# sed -n "p;n" 1.txt
结果输出
1
3
5
说明:
处理第一行:p
打印,n
读取第二行
因为-n
静默,第二行处理完毕
处理第三行:p
打印,n
读取第四行
……
2.4.4 q
退出
3. 选项
3.1 -e
作用
允许多项编辑语法
# sed -e "命令" -e "命令"
示例:
# sed -e "s/1/a/g" -e "1abbbb" 1.txt
- 拓展分析1
-e
罗列的几个命令是依次处理的
试验:“命令1”将1替换为a,“命令2”将a替换为b
# sed -e "s/1/a/g" -e "s/a/b/g" 1.txt
结果最终被替换为b
b
2
3
4
5
-
拓展分析2
但整行替换命令2为何会失效??
# sed -e "1ca" -e "s/a/b/g" 1.txt
结果如下
a
2
3
4
5
3.2 -f
指定sed脚本文件
语法:
# sed -f 脚本名 文件名
示例
sed文件内容如下
s/1/a/g
s/2/b/g
s/3/c/g
通过sed脚本修改1.txt文件
# sed -f sed 1.txt
3.3 -n
静默( 取消默认的输出)
3.4 -i
就地编辑
3.5 -r
支持扩展元字符
3.5.1 ()
分组
- 示例
# sed -r 's/(goo)gle/\1GLE/g' google.txt
说明:括号里表示组1,因此后边
\1
引用组1内容。
替换结果如下
111111
222222
333333
4gooGLE4
555555
66gooGLE
3.5.2 &
表示前边查到的内容
# sed -r 's/google/&AAA/g' google.txt
&
表示前边查到的
结果输出如下:
111111
222222
333333
4googleAAA4
555555
66googleAAA
3.5.3 {M}
作用:
表示前导字符出现M次,M支持正则,支持地址扩展(见后边“五、地址扩展”)示例1
# sed -r 's/go{1,3}gle/Goole/g' google.txt
说明:查找前导o出现1到3次的情况
示例2
# sed -r 's/go{*}gle/Goole/g' google.txt
说明:匹配任意个前导
o
,查找内容处可用*
.
等正则,但新内容处不可用。
3.5.4 #
代替反斜杠
如果替换的原字串或新字串中有反斜杠,则用
#
代替替换命令中的反斜杠。
- 示例
源文件内容如下
66goog/le
将goog/le
替换为Google
# sed -r 's#goog/le#Google#g' google.txt
4. 地址扩展
说明
nm表示条件n、条件m,可以但不限于数字
X、Y表示数字X、数字Y
4.1 n,m
含义:从条件n 打印到条件 m(nm不限于数字)
- n、m是数字
sed -n "2,4p" 1.txt
- n、m是字串
说明:从查到字串bbb开始打印,直到查到 ddd为止
# sed -n "/bbb/,/ddd/p" 2.txt
bbbb
cccc
dddd
-
字串和数字混用
说明:从第3行打印到 出现 字串“ddd”
# sed -n "3,/ddd/p" 2.txt
cccc
dddd
4.2 n,+Y
含义:从符合n条件的行起,再处理Y行。(n不限于数字,Y是数字)
- n Y 都是数字
说明:从第5行打印,再打印2行(共计3行)
# sed -n "5,+2p" 1.txt
5
6
7
- n是字串,m是数字
从查到bbb开始打印,再打印两行。
# sed -n "/bbb/,+2p" 2.txt
bbbbb
ccccc
ddddd
4.3 n,~Y
含义:第n行到第一个数字Y的倍数行。
# sed -n "5,~3p" 1.txt
5
6
说明:从第5行,打印到第3行的倍数(即第6行)结束。
4.4 X~Y
含义 X行起,结尾从X+1开始数,数到Y即处理
# sed -n "2~2p" 1.txt
2
4
6
8
说明:从第2行开始处理(打印),下一位开始计数,数到2就打印该行。
5. 高级命令
h
模式空间内容复制到暂存缓冲区(覆盖)
H
模式空间内容追加到暂存缓冲区
g
提取缓冲区的内容到模式空间。
G
追加缓冲区的内容到模式空间
x
交换两空间内容。