zoukankan      html  css  js  c++  java
  • Linux sed命令 -- 三剑客老二

    格式:

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

      sed [OPTION]... ‘地址定界+[高级]编辑命令’  file

    常用选择:

      i    :修改内容

      i.bak  :先备份,然后再修改内容

      r    :支持正则表达式

      e    :支持多点编辑

      n    :不输出模式空间内容到屏幕,即不自动打印

    '地址定界+[高级]编辑命令'

      地址定界

         1.不给地址:

          对全文进行处理

         2.单地址:

          #:指定的行 , $:最后一行

          /pattern/:被此处模式所能够匹配到的每一行

         3.地址范围

          #,#

          #,+#

          /pat1/,/pat2/

          #,/pat1/

         4. ~:步进

          1~2 奇数行

          2~2 偶数行

      编辑命令

        d:删除模式空间匹配的行,并立即启用下一轮循环

        p:打印当前模式空间内容,追加到默认输出之后

        a[]text:在指定行后面追加文本,支持使用 实现多行追加

        i[]text:在行前插入文本

        c[]text:替换行为单行或多行文件

        w /path/somefile:保存模式匹配的行至指定文件

        r /path/somefile:读取指定文件的文本至模式空间中匹配到的行后

        =:为模式空间中的行打印行号 !:模式空间中匹配行取反处理

      高级编辑命令 P:打印模式空间开端至 内容,并追加到默认输出之前

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

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

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

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

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

        d:删除模式空间中的行

        D:如果模式空间包含换行符,则删除知道第一个换行符的模式空间中的文本, 并不会读取新的输入行,而使用合成的模式空间重新启动循环。如果模式空间不包含换行符,则会像发 出d命令那样启动正常的新循环

    基本正则模式匹配

        匹配字符:

          . :任意一个字符。

          [abc] :表示匹配一个字符

          [a-Z] :表示匹配一个字符

          [^123] :匹配一个字符,这个字符是除了1、2、3以外的所有字符。

          对于一些常用的字符集,系统做了定义:

          [a-Z] 等价于 [[:alpha:]]

          [0-9] 等价于 [[:digit:]]

          [a-Z0-9] 等价于 [[:alnum:]]

          tab,space 等空白字符 [[:space:]]

          [A-Z] 等价于 [[:upper:]]

          [a-z] 等价于 [[:lower:]]

          标点符号 [[:punct:]]

        匹配次数:

          {m,n} :匹配其前面出现的字符至少m次,至多n次。
          ? :匹配其前面出现的内容0次或1次,等价于{0,1}。
          * :匹配其前面出现的内容任意次,等价于{0,},所以 ".*" 表述任意字符任意次,即无论什么内容全部匹配。

        位置锚定:

          ^ :锚定行首

          $ :锚定行尾。技巧:"^$"用于匹配空白行。

          或<:锚定单词的词首。如"like"不会匹配alike,但是会匹配liker

          或>:锚定单词的词尾。如"like"不会匹配alike和liker,只会匹配like

          B :与作用相反。

        分组及引用:

          (string) :将string作为一个整体方便后面引用

            1 :引用第1个左括号及其对应的右括号所匹配的内容。

            2 :引用第2个左括号及其对应的右括号所匹配的内容。

             :引用第n个左括号及其对应的右括号所匹配的内容。

    扩展正则模式匹配

      匹配字符:

          跟基本正则用法一样

      匹配次数:

          {m,n} :匹配其前面出现的字符至少m次,至多n次。
          ? :匹配其前面出现的内容0次或1次,等价于{0,1}。
          * :匹配其前面出现的内容任意次,等价于{0,},所以 ".*" 表述任意字符任意次,即无论什么内容全部匹配。

          +:匹配前面出现的内容1次或1次以上

      位置锚定:

          跟基本正则用法一样

      分组及引用:

          (string) :将string作为一个整体方便后面引用

            1 :引用第1个左括号及其对应的右括号所匹配的内容。

            2 :引用第2个左括号及其对应的右括号所匹配的内容. 

             :引用第n个左括号及其对应的右括号所匹配的内容。

      扩展增用法:

          str | num:匹配 str 或 num 内容

    例题
    1.删除/etc/grub2.cfg文件中所有以空白开头的行行首的空白字符

    [root@cloud ~]# sed -r "/^[[:space:]]*$/d" /etc/grub2.cfg

    2.删除/etc/fstab文件中不以#开头,后面至少跟一个空白字符的行的行首的和空白字符

    [root@cloud ~]# sed -r "/^# *|^$/d" /etc/fstab

    3.在/etc/fstab文件中不以#开头的行的行首增加#号

    [root@cloud ~]# sed -r -n "/^[^#]/s/(.*)/#1/p" /etc/fstab

    4.处理/etc/fstab路径使用sed命令取出其目录和基名

    [root@cloud ~]# echo /etc/fstab | sed -r "s@(.*/)(.*$)@2@"

    5.利用sed取出ifconfig命令中本机的IPv4地址

    [root@cloud ~]# ifconfig eth0 | sed -r -n "s/.*inet (.*) net.*/1/p"

    6.统计centos安装光盘中Package目录下的所有rpm文件的以. 分割倒数第二个字段的重复次数

    [root@cloud ~]# mount /dev/cdrom /opt/dvd
    [root@cloud ~]# ls /opt/dvd/Packages/ | sed -r "s/.rpm$//" | sed -r "s/.*.(.*)/1/" | sort | uniq -c
    [root@cloud ~]# ls /opt/dvd/Packages/ | sed -r "s/.*.(.*).rpm/1/" | sort | uniq -c

    7.将文本文件的n和n+1行合并为一行,n为奇数行

    [root@cloud ~]# seq 10|xargs -n2
    [root@cloud ~]# seq 10|sed 'N;s/
    / /'
  • 相关阅读:
    leetcode: power of three 三种解法
    继续写java和socket
    node中的事件发射器
    谈一谈Crsf和XSS攻击
    谈一谈那些框架们
    【Mysql数据库】学习笔记
    【数据库】DML-增删改查-SQL实现
    【Jsp,Servlet初学总结】 含 cookie和session的使用
    struct和typedef struct彻底明白了
    Android 学习之路
  • 原文地址:https://www.cnblogs.com/mycloudedu/p/11598196.html
Copyright © 2011-2022 走看看