文本处理“三剑客”之SED”

一、SED行编辑器

      sed是stream editor的简称,Sed本质上是一个编辑器,但是它是非交互式的流编辑器。

 

sed的处理流程:

1.读入一行内容到模式空间(Pattern Space)

2.对模式空间里的内容执行sed命令

3.输出模式空间的内容,当输出内容后,模式空间将被清空

4重复以上的操作,直到文件的最后一行。

二、sed命令的语法

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

                       script:地址定界编辑命令

常用选项[OPTION]

        -n:不输出模式空间中的内容至屏幕;

        -e script, --expression=script:多点编辑;

        -f  /PATH/TO/SED_SCRIPT_FILE

               每行一个编辑命令;

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

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

地址定界:

1) 空地址:对全文进行处理;

2) 单地址:#:指定行;

         /pattern/:被此模式所匹配到的每一行;

3) 地址范围

         #,#:从起始行到结束行

         #,+#:如3,8指从第三行(包含第三行),向下八行。

        #,/pat1/:从第#行开始到能第一次被模式匹配到行结束。

        /pat1/,/pat2/:从能被模式1匹配到行开始到能被模式2匹配到的行结束。

        $:最后一行;

4) 步进:~

         1~2:所有奇数行

         2~2:所有偶数行

编辑命令:

d:删除;删除被模式匹配到行即1、3、5行;

p:显示模式空间中的内容;被模式匹配到的行显示两次。

a  \text:在行后面追加文本“text”,支持使用\n实现多行追加;

i  \text:在行前面插入文本“text”,支持使用\n实现多行插入;

c  \text:把匹配到的行替换为此处指定的文本“text”;第一行被替换为"new line"。

w /PATH/TO/SOMEFILE:保存模式空间匹配到的行至指定的文件中;

把"sedtest.txt"中不是#号开头的行,保存到"newsed.txt"中。

r  /PATH/FROM/SOMEFILE:读取指定文件的内容至当前文件被模式匹配到的行后面;文件合并;

把"newsed.txt"中的内容追加到"sedtest.txt"第6行的后边。

=:为模式匹配到的行打印行号;

!:条件取反;地址定界!编辑命令;显示不是#号开头的行

s///:查找替换,其分隔符可自行指定,常用的有s@@@, s###等;替换标记:

       g:全局替换;

       w /PATH/TO/SOMEFILE:将替换成功的结果保存至指定文件中;

       p:显示替换成功的行;

练习1:将/etc/grub2.cfg文件中所有以空白字符开头的行的行首的空白字符替换成“magedu”;

练习2:输出一个绝对路径给sed命令,取出其目录,其行为类似于dirname;

三、高级编辑命令:

    另外一个缓存空间——保持空间(Hold Space),保持空间用于保存模式空间的内容,模式空间的内容可以复制到保持空间,同样地保持空间的内容可以复制回模式空间。

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

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

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

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

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

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

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

d:删除模式空间中的行;

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

示例:

sed  -n  'n;p'  FILE:显示偶数行;

sed  '1!G;h;$!d'  FILE:逆序显示文件的内容;

sed  '$!d'  FILE:取出最后一行;

 sed  '$!N;$!D' FILE:取出文件后两行;

sed  '/^$/d;G' FILE:删除原有的所有空白行,而后为所有的非空白行后添加一个空白行;

sed  'n;d'  FILE:显示奇数行;

sed 'G' FILE:在原有的每行后方添加一个空白行;