grep灵活的关联正则表达式实现文件过滤,而sed是一个数据流的编辑器,或者说是一个行编辑器,它将文件一行一行的数据放入到内存中进行编辑,而awk是一个报告生成器,这个我们以后再说;
之前我们介绍过grep与正则表达式,这一节我们详细介绍sed的用法
sed的基本用法
sed Stream EDitor 流编辑器,也叫做行编辑器;它是一个字处理器工具【与字处理工具相对应的就是文本编辑器,类似于nona或者vi vim(他们都是文本编辑器,或者说是全屏编辑器)】
sed并不是直接去处理文件本身,而是将每一行的数据读取到内存中区,再在内存中进行处理,并显示在屏幕上。而内存提供出来处理这个数据的空间我们叫做模式空间。
需要注意的是,sed命令默认不编辑源文件,仅对模式空间中的数据进行修改和处理,然后处理结束后,将模式空间中处理好的数据显示在屏幕上。
sed命令的用法
sed [option] ... {script-only-if-no-orther-script} [input-file]
这里的script-only-if-no-orther-script可以理解为sed命令自己的语言,它有自己独立的语法结构;
sed [option] 'AddressCommand' file ...
option 选项类型
-n 静态模式,不再默认显示模式空间中的内容
-i 直接修改原文件(这种做法很危险)
-e -e Script 表示可以同时执行多个脚本
-f /path/to/sed_script 将脚本文件写在其他脚本中,这样就需要通过-f来调用这个脚本文件
-r 表示可以使用扩展的正则表达式
Address 表示需要处理的对象的行或者地址
1、startline,endline
1,100 #表示处理第一行到第一百行;
$ 表示处理最后一行;
$-1 表示处理倒数第二行;
2、也可以指定模式,使用正则表达式 /RegExp/ (例如:/^root/ 表示匹配以root开头的字符)
3、也可以指定模式:/pattern1/,/pattern2/
第一次被pattern1匹配到的行开始,至第一次被pattern2匹配到的行结束,这中间所有的行都会被匹配到。
4、linenumber
精确指定某行进行匹配
5、StartLine,+N
从指定的行开始,到后面的N行,都会被匹配上,总共N+1行;
Command 指定sed选出来后的行为
d 表示删除符合条件的行
sed '1,2d' /etc/fstab
sed '3,$-1d' /etc/fstab
sed '/oot/d' /etc/fstab #删除包含有“oot”字符串的行
sed '1,+2d' /etc/fstab
sed '1d' /etc/fstab
p 表示显示(打印)符合条件的行
sed '/^//p' /etc/fstab #打印以 / 开头的行,其中 表示转意符
sed -n '/^//p' /etc/fstab #-n表示不再默认显示模式空间中的内容
a 在匹配到的行后面增添新的内容
a “string” 这样写表示后面再新增string内容;
sed '/^//a hello world' /etc/fstab
sed '/^//a hello world #hello,linux' /etc/fstab #其中 表示换行符号
i 在指定的前面添加新的内容,内容为string
sed '/^//i hello world ' /etc/fstab
r filename 将指定的文件内容添加到符合条件的行处
sed '2r /etc/issue' /etc/fstab #在第二行的地方将文件/etc/issue的内容添加进来
sed '1,2r /etc/issue' /etc/fstab
w filename 将指定范围的内容另存为一个指定的文件
sed '/oot/w /tmp/oot.txt' /etc/fstab #将包含“oot”字符串的行从新保存至/tmp/oot.txt文件中去
s 查找并替换相关的内容
s/pattern/sting/ 将pattern匹配到的内容替换为后者string的内容,而pattern是支持正则表达式的;
默认情况下,s命令只替换每行中第一次被pattern匹配到的字符串,如果想要将所有匹配到的字符串均进行替换,就需要再最后面加上:g 全局替换参数,i 忽略字符大小写参数;
【s命令的分隔符可以使用 / ,同时,也可以换成其他的符号,例如:s@pattern@string@、s#pattern#string#】
sed 's/oot/OOT/' /etc/fstab
sed 's/^//#/' /etc/fstab
sed 's@/@#@' /etc/fstab
sed 's/l/L/g' /etc/fstab
sed语句的后向引用
& 用来匹配前面pattern关联的整个字符串;
sed 's#l..e#&r#g' sed.txt
sed 's#(l..e)#1r#g' sed.txt
但是,在一些情况下必须使用后向引用,而不能使用&符来调用之前的pattern所匹配的内容