sed是linux中比较常用的文本编辑类命令,规则为逐行输出
其比较常用的用法如下:
sed [OPTION] {SCRIPT} FILENAME
主要[OPTION]:
-n:不再显示默认模式空间中的内容
-i:修改源文件
-e:同时执行多个操作
例如:sed -e {SCRIPT} -e {SCRIPT} ...
-f:指定脚本文件处理文本内容
例如:sed -f SCRIPTNAME FILENAME
-r:允许使用扩展的正则表达式(同grep -e 或者 egrep)
{SCRIPT}可拆分为两部分即{AddressCommand}
Address:为寻址部分:需找符合要求或者能够匹配到的行
主要有以下几种表达方式(注:实例中的p为上面提到的Command):
1、精确匹配行(StartLine,EndLine):
例如:5 第五行 sed ‘5p‘ filename
2、范围匹配行(LineNumber):其中$表示最后一行
例如:第3到第6行 sed ‘3,6p‘ filename
3、从某行开始,向后多少行(StartLine,+N):
例如:从第3开始向后10行 sed ‘3,+10p‘ filename
4、模式匹配(/pattern/):根据模式匹配到的行
例如:匹配以root字符开头,且为一个单词的行
sed ‘/^root\>/p‘ filename
5、模式范围匹配(/pattern1/,/pattern2/):第一次被pattern1匹配到的行开始到第一次被pattern2匹配到的行结束,之间所有的行
例如:匹配以use1字符开头的行,到以user10开头的行之前的所有行
sed ‘/^user1\>/,/^user10\>p‘ filename
Command:需要执行的编辑命令
-d:删除匹配到的行
-p:显示匹配到的行
-i \string: 在匹配到的行上一行插入文本信息
-a \string: 在匹配到的行下一行插入文本信息
-r filename:将指定文件的内容添加到匹配到的行处
-w filename:将匹配到的行信息保存到指定文件中
-s/pattern/string/修饰符/:将匹配到的字符替换为string,默认为替换一行中第一次匹配到的字符
修饰符:g 全局替换
i 忽略大小写
例如:匹配root字符全部替换成user1
sed ‘s/root/user1/g‘ filename
其中分隔符///可以用其他符号替代: 例如 @ 等
例如:
sed ‘[email protected]@[email protected]‘ filename
此模式中也可以用分组引用功能:
例如:将所有匹配到的u..r字符的u改为大写
sed ‘s/u\(..r\)/U\1/g‘ filename