sed工具使用

sed命令使用形式

1.sed命令从管道中读取数据处理

  command | sed ' edit command' 通过管道把一个命令的标准输出读入到sed的标准输入,sed就起到了过滤作用

2.sed命令通过命令行参数从文件中读取数据

  sed    [-nefri]   'edit command'    filename  

    -n  :使用安静(silent)模式。在一般sed 的用法中,所有来自STDIN 的数据一般都会被列出到屏幕上。但如果加上-n 参数后,则只有经过sed 特殊处理的那一行(或者动作)

才会被列出来。

  -e  :直接在指令列模式上进行sed 的动作编辑;

-f  :直接将sed 的动作写在一个档案内,-f filename 则可以执行 filename 内的sed 动作;

-r  :sed 的动作支持的是延伸型正规表示法的语法。

     (预设是基础正规表示法语法) 

-i  :直接修改读取的档案内容,而不是由屏幕输出。

   

   sed [-nefri] [动作]

动作说明:

       [n1[,n2]]function

      n1, n2 :不见得会存在,一般代表『选择进行动作的行数』,

       举例来说,如果我的动作 是需要在 10 到 20 行之间进行的,则10,20[动作行为]

    function 有底下:

       a :新增, a 的后面可以接字符串,而这些字符串会在新的一行出现(目前的下一行)~

       c :取代, c 的后面可以接字符串,这些字符串可以取代 n1,n2 之间的行!
       d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;

       i :插入, i 的后面可以接字符串,而这些字符串会在新的一行出现(目前的上一行);

       p :打印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运作~
       s :取代,可以直接进行取代的工作!通常这个 s 的动作可以搭配 正规表示法!

         例如 1,20s/old/new/g  
  范例:      在第二行后(亦即是加在第三行)加上drink tea字样

         [root@linux ~]# nl  /etc/passwd |sed '2a drink tea'

                            1 root:x:0:0:root:/root:/bin/bash

                            2 bin:x:1:1:bin:/bin:/sbin/nologin drink tea

                            3 daemon:x:2:2:daemon:/sbin:/sbin/nologin

          # 在 a 后面加上的字符串就已将出现在第二行后面啰!那如果是要在第二行前呢?

           # nl /etc/passwd | sed '2i drink tea' 

范例:   在第二行后面加入两行字,例如『Drink tea or .....』『drink beer?』

             [root@linux ~]# nl /etc/passwd | sed '2a Drink tea or ...... > drink beer ?'

                                1   root:x:0:0:root:/root:/bin/bash

                                2 bin:x:1:1:bin:/bin:/sbin/nologin

                                Drink tea or ......

                                drink beer ?

                                3 daemon:x:2:2:daemon:/sbin:/sbin/nologin

                     # 这个范例的重点是,我们可以新增不只一行喔!可以新增好几行~              

                     # 但是每一行之间都必须要以反斜线 来进行新行的增加喔!所以,上面的例子中,

                   # 我们可以发现在第一行的最后面就有 存在啦!那是一定要的喔
范例: 我想将第2-5行的内容取代成为『No 2-5 number』呢?

 [root@linux ~]# nl /etc/passwd | sed '2,5c No 2-5 number'

                       1 root:x:0:0:root:/root:/bin/bash

                      No 2-5 number

                      6 sync:x:5:0:sync:/sbin:/bin/sync # 没有了 2-5 行,嘿嘿嘿嘿!我们要的数据就出现啦!

范例五:仅列出第 5-7 行

[root@linux ~]# nl /etc/passwd | sed -n '5,7p'

                      5 lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin

                      6 sync:x:5:0:sync:/sbin:/bin/sync

                      7 shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown

                    为什么要加 -n 的参数呢?您可以自行下达 sed '5,7p' 就知道了!(5-7行会重复输出) # 有没有加上 -n 的参数时,输出的数据可是差很多的喔!

范例六:我们可以使用 ifconfig 来列出 IP ,若仅要 eth0 的 IP 时?
[root@linux ~]# ifconfig eth0

                    eth0 Link encap:Ethernet HWaddr 00:51:FD:52:9A:CA

                    inet addr:192.168.1.12 Bcast:192.168.1.255 Mask:255.255.255.0

                    inet6 addr: fe80::250:fcff:fe22:9acb/64 Scope:Link UP BROADCAST RUNNING MULTICAST

                    MTU:1500 Metric:1 .....(以下省略).....

 # 其实,我们要的只是那个 inet addr:..那一行而已,所以啰,利用 grep 与 sed 来捉

[root@linux ~]# ifconfig eth0 | grep 'inet ' | sed 's/^.*addr://g' | sed 's/Bcast.*$//g'

 # 您可以将每个管线 (|) 的过程都分开来执行,就会晓得原因啰!

 # 去头去尾之后,就会得到我们所需要的 IP 亦即是 192.168.1.12

 范例七:将 /etc/man.config 档案的内容中,有 MAN 的设定就取出来,但不要说明内容。

[root@linux ~]# cat /etc/man.config | grep 'MAN'| sed 's/#.*$//g' |  sed '/^$/d'

# 每一行当中,若有 # 表示该行为批注,但是要注意的是,有时候, # 批注并不是写在第一个字符,亦即是写在某个指令后方,如底下的模样: # 『shutdown -h now

# 这个是关机的指令』,批注 # 就在指令的后方了。 # 因此,我们才会使用到将 #.*$ 这个正规表示法!

范例八:利用 sed 直接在 ~/.bashrc 最后一行加入# This is a test

[root@linux ~]# sed -i '$a # This is a test' ~/.bashrc

# 上头的 -i 参数可以让你的 sed 直接去修改后面接的档案内容喔!而不是由屏幕输出。

# 至于那个 $a 则代表最后一行才新增的意思。

    

 

 

 

 edit command 的命令形式为:

                                        /pattern/action

 /pattern/为一个正则表达式 / / 两个反斜杠表示正则表达式 ^ 开始$结束

 action 表示对正则表达式的操作指定。

  p 打印行print

  s  替换   s/part1/part2/g   g表示全局替换

  d  删除delete  ‘d’ 这个字符就是删除的动作了,不仅可以删除指定的单行以及多行,而且还可以删除匹配某个字符的行,另外还可以删除从某一行一直到文档末行。

  = 显示行号

   sed命令不会改变提供数据的原始文件,它只对流进过它的数据进行修改,输出的标准输出,如果需要保存文件,则要重定向到临时文件中在覆盖原来文件。

   sed  -n  -e  '/^root/p' -e   '/^yuan/p'  /etc/passwd

   sed -n 's/root/123/p' /etc/passwd

   注意:-n选项将禁止sed编辑器输出,但p替换标记会输出修改过的行,将二者配合全盘则会只输出被substitute命令修改过的行。

  sed   -n   's/yuan/123/;s/anqin/555/p'   12.txt

1.打印匹配的行

   打印第10行的类容

   sed -n '10'p  /etc/passwd

  -n表示打印行数

   p表示打印

  '10'p后面接p不允许空格 p也可以写到'10p'里面

2.打印匹配范围

  打印所有行

  sed -n '1,$'p  /etc/passwd

  打印1-5行类容

  sed -n '1,$'p  /etc/passwd

3.打印匹配模式

    /pattern/

    打印包含root的行

    sed  -n   '/root/p'  /etc/passwd

4 实现多个行为

     sed  -n  -e  '/^root/p' -e   '/^yuan/p'  /etc/passwd

5.删除某行或者多行或者某个元素行

     sed  '1'd  /etc/passwd

     sed  ' 1,5'd  /etc/passwd

     sed   '/yuan/'d /etc/passwd

     匹配元字符 $前,必须使用反斜线 屏蔽其特殊含义。模式为 /$/ p 。

      如:

        sed -n ' / $ / '   /etc/passwd

   6.替换字符或字符串

      替换命令用替换模式替换指定模式,格式为:
      [ a d d r e s s [ , address]] s/ pattern-to-find /replacement-pattern/[g p w n]

        sed  '1,4s/ abc/ABC/g'   /etc/passwd

        sed   '1,4s @abc@ABC@g'  /etc/passwd

        sed    '1,4s#abc#ABC#g'   /etc/passwd

        表示把/etc/passwd文件中的1-4行的abc全部替换为ABC

        上例中的 ‘s’ 就是替换的命令, ‘g’ 为本行中全局替换,如果不加 ‘g’ 只换该行中出现的第一个。

        除了可以使用 ‘/’ 作为分隔符外,还可以使用其他特殊字符例如 ‘#’ 或者 ‘@’ 都没有问题。

  7.调换两个字符串的位置    

[root@yua ~]# sed -n '1'p 12.txt
root:x:0:0:root:/root:/bin/bash


[root@yu~]# sed -n  's!(root)(.*)(bash)!321!'p   12.txt
bash:x:0:0:root:/root:/bin/root

[root@yuananqin ~]# sed -n '1'p 12.txt
root:x:0:0:root:/root:/bin/bash


[root@yuananqin ~]# sed -n 's@(root)(.*)(bash)@321@'p   12.txt
bash:x:0:0:root:/root:/bin/root

      sed  '1,5s@(root) (.*)(bash)@321@'g    /root/test.txt

   8.在行的前面或者后面贴加字符

      sed  's /^.*$ / 222&/ 'g   /root/12.txt 

    9.直接修改文件的内容 

       sed -i  's/ot/to/g'  test.txt

   

  

原文地址:https://www.cnblogs.com/yuankaituo/p/4286042.html