shell基础-07 sed 流编辑器(插入、替换、删除、选项、正则、地址扩展、高级命令)

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

&表示前边查到的google

结果输出如下:

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

image.jpeg

  • 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 交换两空间内容。


posted on 2021-09-18 14:19  运维开发玄德公  阅读(39)  评论(0编辑  收藏  举报  来源

导航