首页 > 代码库 > sed
sed
sed命令:
流编辑器,按照行为单位对一个或多个文件进行编辑处理;每一次sed都会处理给定文件中的一行内容。
在sed处理文本时,将正在处理的当前行存储到临时缓冲区中,称为”模式空间“;用当前行去匹配给定的pattern,如果能匹配,则使用command编辑处理,如果不匹配,则默认输出值标准输出,然后继续处理下一行;直到这个文件的末尾。
默认情况下,sed的所有处理行为不会影响原文件的内容;
我们一般会使用sed命令来自动编辑一个或多个文件,然后简化对于文件的循环操作,
sed - stream editor for filtering and transforming text
sed [OPTION]... ‘script‘ [input-file]...
选项
-n:对于不能匹配模式的行,默认不输出到屏幕
-e script:多条件编辑
-f script-file:从指定的script-file中读取脚本
注意:script-file为一个能够定位到脚本文件的路径最好为绝对路径
-i:原文件直接编辑操作
-r:使sed支持扩展正则表达式;
script:
‘AddressesCommand‘:地址与命令之间没有空格,必须单引号引用
Addresses(地址定界):
1.空地址:对所有文件的所有行进行处理;
2.单地址:sed对于能够匹配该地址的那唯一一行进行处理;
num:表示行号
/pattern/: 能够匹配该模式的所有行
$: 最后一行
3.地址范围:
addr1,addr2:从addr1开始到addr2结束的中间所有行;包括addr1和addr2
例如:2,8,从第2行到第8行
first~step:从first标记的行号开始,以step所代表的数字为步长来计算;
例如:1~2,第1行 第3行,第5行
addr1,+N:从addr1开始,包括addr1所在行并继续向后计算N行;
例如:2,+7 第2行开始,在数7行,总共8行,相当于2,2+7
addr1,~N:从addr1开始包括addr1所在行,向后计算addr1*N行
例如:2,~5相当于 2,2*5
/pattern1/,/pattern2/: 从被pattern1匹配的第一行开始计算,一直到被pattern2匹配到的第一行结束;
Command
=:显示被模式匹配的行的行号
a \text: 在被模式匹配的行的后面追加text内容,支持使用\n换行,从而实现多行追加
i \text: 在被模式匹配的行的前面插入text内容,支持使用\n换行,从而实现多行插入
c \text: 在被模式匹配的行的修改为text内容,支持使用\n换行,从而实现一行换多行
d:在模式空间空间中删除被模式匹配的行;这样的行就不能在进行标准输出;
注意:在使用d命令时不宜使用-n选项
p:显示模式空间中被模式匹配的行;
注意:在使用p命令时,通常会搭配-n选项
w filepath:将模式空间中被匹配的行,另存到filepath文件中
r filepath:将filepath文件的内容追加至模式空间中被模式匹配的行之后
!Command:在模式空间中被模式匹配的行,不执行Command命令;相反未被模式匹配的行才会执行Command命令
s///:查找替换,分隔符可以任意更换,只要相同即可 s### s@@@都可以
s/pattern/text/[control]
pattern:计划查找替换的内容
text:要替换的结果
control:如何进行替换
g: 行内全部替换
p: 显示替换成功的行
w filepath:将替换成功的行另存到filepath中;
支持后向引用:
s/\(string\)/&/
s/\(string\)/\1/
高级编辑命令:
h: 把模式空间中的内容覆盖至保持空间中
H:把模式空间中的内容追加至保持空间中
g: 从保持空间取出数据覆盖至模式空间
G:从保持空间取出内容追加至模式空间
x: 把模式空间中的内容与保持空间中的内容进行互换
n: 读取匹配到的行的下一行覆盖至模式空间
N:追加匹配到的行的下一行至模式空间
d: 删除模式空间中的行
D:删除多行模式空间中的所有行
示例:
sed -n ‘n;p‘ FILE
sed ‘1!G;h;$!d‘ FILE
sed ‘$!N;$!D‘ FILE
sed ‘$!d‘ FILE
sed ‘G’ FILE
sed ‘g’ FILE
sed ‘/^$/d;G’ FILE
sed ‘n;d‘ FILE
sed -n ‘1!G;h;$p‘ FILE
sed