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 's@root@user1@g' filename

此模式中也可以用分组引用功能:

例如:将所有匹配到的u..r字符的u改为大写

sed 's/u\(..r\)/U\1/g' filename