sed命令用法


sed:Stream EDitor,流编辑器,以行为单位对一个或多个文件进行编辑处理;每一次sed都会处理给定文件中的一行内容。


在sed处理文本时,将正在处理的当前行存储到临时的缓冲区中,称为“模式空间”;用当前行去匹配给定的PATTERN,如果能匹配,则使用command编辑处理;如果不匹配,则默认输出至标准输出;然后继续处理下一行,直到文件的末尾。


默认情况下,sed的所有处理行为不会影响源文件的内容,除非我们加上-i选项。


sed命令可以自动编辑一个或多个文件,简化对文件的循环操作。


我们先来了解一下sed命令的相关用法:

sed命令:

sed - stream editor for filtering and transforming text

sed [OPTION]... 'script' [input-file]...

常用选项:

-n, --quiet, --silent:对于不能匹配模式的行,默认不输出到屏幕;

-e script, --expression=script:多条件编辑;

-f script-file, --file=script-file:从指定的script-file中读取脚本

注意:script-file为一个能够定位到脚本文件的路径,最好为绝对路径

-i[SUFFIX], --in-place[=SUFFIX]:原文件直接编辑操作;

-r, --regexp-extended:使sed支持扩展正则表达式;


script:

'AddressesCommand'


Addresses(地址定界):

1.空地址:对所有文件的所有行进行处理;

2.单地址:sed对于能够匹配该地址的那唯一一行进行处理;

num:表示行号;

/pattern/:能够匹配该模式的所有行;

pattern:

.:任意单个字符

.*:任意字符


$:表示文档最后一行

3.地址范围:

addr1,addr2:从addr1开始到addr2结束的中间所有行;

例如:2,8

first~step:从first标记的行号开始,以step所代表的数字为步长;

例如:1~2, 2~2

addr1,+N:从addr1开始,包括addr1所在行,并继续向后计算N行;

例如:2,+7相当于2,2+7

addr1,~N:从addr1开始,包括addr1所在行,向后计算addr1*N行;

例如:2,~5相当于2,2*5

/pattern1/,/pattern2/:从被pattern1匹配的第一行开始计算,一直到                                                 被/pattern2/匹配到的第一行结束;


Command(处理命令):

=:显示被模式匹配的行的行号

例如:sed -n '/^#/=' /etc/grub2.cfg    //显示以#号开头的行的行号

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,,,

s/pattern/text/[control]

s@/etc/fstab@/etc/mtab@

         s/\/bin//123/

pattern:计划查找并替换的内容

text:要替换的结果

control:如何进行替换

g:行内全部替换

p:显示替换成功的行

w filepath:将替换成功的行另存到filepath文件中;


支持后向引用:

s/\(string\)/&abc/     //紧跟string的后面加上abc

s/\(string\)/\1abc/    //紧跟string的后面加上abc


高级编辑命令:

h: 把模式空间中的内容覆盖至保持空间中

H:把模式空间中的内容追加至保持空间中

g: 从保持空间取出数据覆盖至模式空间

G:从保持空间取出内容追加至模式空间

x: 把模式空间中的内容与保持空间中的内容进行互换

n: 读取匹配到的行的下一行覆盖至模式空间

N:追加匹配到的行的下一行至模式空间

d: 删除模式空间中的行

D:删除多行模式空间中的所有行


事实上,我们对文件的操作无非就是“增删改查”。所以下面就举几个例子来说明sed命令的使用。

ex]# cat 1
   hello hello  
#  1234567890 
abcdefg
ABCDEFG
  #123 456 789
#hijklnm

OPQRST UVWXYZ

1.在原文件的基础上“增加”内容

  在以“#”号开头的行的后面增加“@@@”; 

ex]# sed '/^#/a \@@@' 1
   hello hello  
#  1234567890 
@@@
abcdefg
ABCDEFG
  #123 456 789
#hijklnm
@@@

OPQRST UVWXYZ

  在以“#”号开头的行的前面面增加“@@@”;

ex]# sed '/^#/i \@@@' 1
   hello hello  
@@@
#  1234567890 
abcdefg
ABCDEFG
  #123 456 789
@@@
#hijklnm

OPQRST UVWXYZ

  在以“#”号开头的行的“123”内容的后面增加“@@@”;

 ex]# sed -n '/^#/s/123/@@@&/gp' 1
#  @@@1234567890


2.在原文件的基础上“删除”内容

  删除空白行;

 ex]# sed '/^$/d' 1
   hello hello  
#  1234567890 
abcdefg
ABCDEFG
  #123 456 789
#hijklnm
OPQRST UVWXYZ

  删除以空格开头的非空白行;

 ex]# sed '/^[ ]/d' 1
#  1234567890 
abcdefg
ABCDEFG
#hijklnm

OPQRST UVWXYZ

  将开头有空格的非空白行的前面的空格删除;

ex]# sed 's/^[ ]*//g' 1
hello hello  
#  1234567890 
abcdefg
ABCDEFG
#123 456 789
#hijklnm

OPQRST UVWXYZ

  将以“#”号开头的行的“123”内容删除;

 ex]# sed '/^#/s/123//g' 1
   hello hello  
#  4567890 
abcdefg
ABCDEFG
  #123 456 789
#hijklnm

OPQRST UVWXYZ


3.在原文件的基础上“修改”内容

  将文件中所有的“123”修改为“321”;

[root@localhost ex]# sed -n 's@123@321@gp' 1
#  3214567890 
  #321 456 789

  将以空格开头的行的“456”修改为“654”

[root@localhost ex]# sed -n '/^[ ]/s/456/654/gp' 1
  #123 654 789