sed命令:流编辑器,一次读取文本中的一行至内存的模式空间中,将符合条件的一行进行编辑处理,在下一行进入模式空间前,模式空间内的行都会被默认标准输出(并不会修改源文件)
    
 

         

        语法:sed [OPTION]... {script} [input-file]...

                       sed [OPTION]... ‘地址定界sed编辑命令’ [input-file]...

            [OPTION]如下:

            -r: 支持扩展正则表达式(sed默认就支持基本正则表达式);
            -n: 静默模式(禁止不符合条件的行被默认标准输出);
            -e script1 -e script2 -e script3:指定多脚本运行作用在文本文件上;
            -f /path/to/script_file:从指定的文件中读取脚本并运行;
            -i: 直接修改源文件;

 

             地址定界:不写则默认为所有行
                #: 指定第#行;
                $: 最后一行;
                /regexp/:任何能够被regexp所匹配到的行;
                \%regexp%:同上,只不过换作%为regexp边界符;
                /regexp/| :
                \%regexp%| :匹配时忽略字符大小写;
                startline,endline:
                    #,/regexp/:从#行开始,到第一次被/regexp/所匹配到的行结束,中间的所有行;
                    #,#
                    /regexp1/,/regexp2/:从第一次被/regexp1/匹配到的行开始,到第一次被/regexp2/匹配到的行结束,中间的所有行;
                    #,+n:从#行开始,一直到向下的n行;
                first~step:指定起始行,以及步长;
                    1~2,2~2

             sed的编辑命令
                d: 删除模式空间中的行;
                =:显示行号;
                a \text(text为字符串):在下一行添加附加text(text为字符串):
                i \text(text为字符串):在上一行插入text(text为字符串):,支持\n实现多行插入;
                c \text(text为字符串):用text(text为字符串):替换匹配到的整行内容;
                p: 打印模式空间中的行;
                s/regexp/replacement/:替换由regexp所匹配到的内容为replacement(默认每行中第一个被匹配的);
                    g: 每行中所有能被匹配的内同都替换;
                   
                w /path/to/somefile:把指定的内容另存至/path/to/somefile路径所指定的文件中;
                r /path/from/somefile:在文件的指定位置插入另一个文件的所有内容,完成文件合并;

              对命令的取反!其实是对地址定界的取反

            示例验证1:

                      image

                      第一个命令1到8行被输出两次原因:sed的编辑命令为p:输出符合地址定界内的行,再加上sed默认会将读取到模式空间内的行标准输出,所以为两次。

                      第二个命令sed 选项为-n,关闭了sed默认会将读取到模式空间内的行标准输出。只有输出符合地址定界内的行可以使用编辑命令p标注输出。

                      

             示例验证2:

                      image
                    g: 每行中所有能被匹配的内同都替换;

            练习:
                (1) 删除/boot/grub/grub.conf文件中所有行的行首的空白字符;
                    sed 's/^[[:space:]]\+//' /boot/grub/grub.conf

                       image
                (2) 删除/etc/fstab文件中所有以#开头,后跟至少一个空白字符的行的行首的#和空白字符;
                    sed 's/^#[[:space:]]\+//' /etc/fstab

                     image
                (3) 把/etc/fstab文件的奇数行另存为/tmp/fstab.3;

                    sed '1~2w/tmp/fstab.3' /etc/fstab  (其中保存路径如不存在则创建保存,若存在会被强制覆盖)

                    image
                    image
                (4) echo一个文件路径给sed命令,取出其基名;进一步地,取出其路径名;
                    取基名:echo "/etc/sysconfig/network-scripts/" | sed 's@^.*/\([^/]\+\)/\?$@\1@'

                                思想方法: 匹配整行路径,基名以组的形式匹配,最后用组替换整行路径
                    取路径名:echo "/etc/sysconfig/network-scripts/" | sed 's@[^/]\+/\?$@@'

                                思想方法:匹配基名后替换为无

                    image
            sed命令还有另一个称作"hold space"的内存空间:

            高级命令:
                h:用模式空间中的内容覆盖保持空间的内容;
                H:把模式空间中的内容追加至保持空间中内容的后面;
                g:从保持空间中取到其内容,并将其覆盖模式空间中的内容;
                G:从保持空间中取到其内容,并将其追加在模式空间中的内容的后面;
                x:把保持空间和模式空间中的进行交换;
                n:读取匹配到的行的下一行至模式空间;(会覆盖模式空间中的原有内容);
                N:读取匹配到的行的下一行至模式空间,追加在模式空间中原有内容的后面;
                d:删除模式空间中的内容;
                D:删除多行模式空间中的首行;

              

            示例:
                sed 'G' /etc/issue: 在文件中的每行后方添加空白行;
                sed '$!d' /etc/fstab:保留最后一行;
                sed '/^$/d;G' /etc/issue: 保证指定的文件每一行后方有且只有一个空白行;
                sed 'n;d' /etc/issue:保留奇数行;
                sed -n '1!G;h;$p' /etc/issue 将行顺序倒序
                sed '$!N;$!D' /etc/issue