sed详解

sed命令:

   文本处理三剑客:

       grep, egrep,fgrep: 文本过滤器

       sed :Stream EDitor, 流编辑器,行

       awk: 文本格式工具,报告生成器

       sed [OPTION]… {script-only-if-no-other-script} [input-file]…

  script:

        地址定界编辑命令

   常用选项:

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

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

       ~]# sed -e 's@^#[[:space:]]*@@' -e'/^UUID/d' /etc/fstab

        -f:/PATH/TO/SED_SCRIPT_FILE

        每行一个编辑命令

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

        -l [SUFFIX]. –in-place[=SUFFIX]:直接编辑原文件;

    地址定界:

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

        (2)单地址:

           # :指定行;

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

        (3)地址范围

            #,#:

            #, +#:

            #, /pat1/

            /pat1/, /pat2/

             $:表示最后一行

         (4)步进:-

            1~2: 所有奇数;

              2~2:所有偶数行

      编辑命令:

           d:删除

           p:显示模式空间的内容;

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

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

           c \text: 把匹配到的行替换为此处指定的文本“text"; 

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

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

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

           !:条件取反;

     地址定界!编辑命令;

           s/// : 查找替换,其分隔符号可自行指定,常用命令s@@@,s###等  

           替换标记:

           g:全局替换;

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

           p: 显示替换成功的行;

    练习1:删除/boot/grub/grub2.cfg文件中所有以空白字符开头的行的行首的所有空白字符;

           ~]# sed 's@^[[:space:]]\+@@' /etc/grub2.cfg

    练习2:删除/etc/fstab文件中所有以#开头的行的行首的#号及#后面的所有空白字符;

            ~]# sed 's@^#[[:space:]]*@@' /etc/fstab

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

           ~]# echo "/var/log/messages/" | sed 's@[^/]\+/\?$@@'

           ~]# echo "/var/log/messages/" | sed -r 's@[^/]+/?$@@'

                    

    高级编辑命令:

        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:在原有的每行后方添加一个空白行;


原创文章,作者:shadow,如若转载,请注明出处:http://www.178linux.com/63487

(0)
shadowshadow
上一篇 2016-12-13
下一篇 2016-12-13

相关推荐

  • N22-​Linux系统的基础命令

                                     Linux系统的基础命令 命令的语法通用格式:# COMMAND OPTIONS  ARGUMENTS COMMA…

    Linux干货 2016-08-15
  • 搜索引擎-网络爬虫

     通用搜索引擎的处理对象是互联网网页,目前网页数量以百亿计,搜索引擎的网络爬虫能够高效地将海量的网页数据传下载到本地,在本地 形成互联网网页的镜像备份。它是搜索引擎系统中很关键也很基础的构件。 1. 网络爬虫本质就是浏览器http请求。      浏览器和网络爬虫是两种不同的网络客户端,都以相同的方式来获取网…

    Linux干货 2015-11-18
  • LVS实现

    一 LVS-NAT实验前的准备 操作系统:CentOS 6.7 64位 配置防火墙,iptables –F 清理防火墙规则或者关闭iptables 关闭SELINUX, setenforce 0  #立即生效(实际是宽容模式) Director ip:172.16.2.1  VIP:192.168.1.8 RS1 ip:172.16.2.…

    Linux干货 2016-12-29
  • N25-第四周作业

    1、复制/etc/skel目录为/home/tuser1,要求/home/tuser1及其内部文件的属组和其它用户均没有任何访问权限。 [root@localhost ~]# cp -r /etc/skel /home/tuser1 [root@localhost ~]# ls …

    Linux干货 2017-01-03
  • 对ssh的简单理解

    ssh:secure shell,protocol,22、tcp安全的远程登录 具体的软件实现:openssh:ssh协议的开源实现,centos默认安装dropbear:另一个开源实现ssh协议版本v1:基于crc-32做MAC,不安全;man-in-middle 已淘汰v2:双方主机协议选择安全的MAC方式基于DH算法做密钥交换,基于RSA或DSA实现身…

    2017-09-29
  • 手动添加用户

        通常使用useradd命令可以轻松添加一个用户,然后使用passwd命令设置一个密码后就可以登录系统了,其实这一过程完成可以自己手动完成,下面就让我们来通过修改配置文件来添加一个用户。 一、修改/etc/passwd文件     在etc/passwd文件中手动添加一行内…

    Linux干货 2015-04-27

评论列表(1条)

  • 马哥教育
    马哥教育 2016-12-23 12:47

    赞~注意下整体的排版~另外几个例子能补充下是实现的什么功能会更好~继续加油~