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/
/ /'
原文地址:https://www.cnblogs.com/mycloudedu/p/11598196.html