首页 > 代码库 > sed常用命令

sed常用命令

-n :使用安静(silent)模式。在一般 sed 的用法中,所有来自 STDIN 的数据一般都会被列出到终端上。但如果加上 -n 参数后,则只有经过sed 特殊处理的那一行(或者动作)才会被列出来。
-e :直接在命令列模式上进行 sed 的动作编辑;
-f :直接将 sed 的动作写在一个文件内, -f filename 则可以运行 filename 内的 sed 动作;
-r :sed 的动作支持的是延伸型正规表示法的语法。(默认是基础正规表示法语法)
-i :直接修改读取的文件内容,而不是输出到终端。

函数:

a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~
s :取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!

用法例如:sed -i s/a/b/g file

把文件file中所有的a替换成b

[root@controller ~]# sed ‘2,5d‘ passwd

上面的命令是把文件passwd第2行到第5行都删除了

[root@controller ~]# sed ‘2,$d‘ passwd

上面的命令是把文件passwd第2行到最后一行都删除了

[root@controller ~]# sed ‘2a zhouyu‘ passwd

上面的命令是在文件passwd的第2行后面加入zhouyu,如图

[root@controller ~]# sed ‘2a zhouyu‘ passwd

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

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

zhouyu

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

4.adm:x:3:4:adm:/var/adm:/sbin/nologin

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

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

如果增加的不止是一行的话,可以用下列命令

[root@controller ~]# sed ‘2a zhouyu \

> zhouziqi‘ passwd

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

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

zhouyu 

zhouziqi

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

4.adm:x:3:4:adm:/var/adm:/sbin/nologin

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

将第2-5行的内容取代成为 no number 2 -5

[root@controller ~]# sed ‘2,5c no number 2-5‘ passwd 

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

no number 2-5

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

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

halt:x:7:0:halt:/sbin:/sbin/halt

mail:x:8:12:mail:/var/spool/mail:/sbin/nologin

operator:x:11:0:operator:/root:/sbin/nologin

仅列出 /etc/passwd 文件内的第 5-7 行

[root@controller ~]# sed -n ‘2,5p‘ passwd 

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

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

4.adm:x:3:4:adm:/var/adm:/sbin/nologin

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

搜索某个关键词并打印出来

[root@controller ~]# sed -n ‘/root/p‘ passwd 

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

operator:x:11:0:operator:/root:/sbin/nologin

如果你只是用sed ‘/root/p‘ passwd命令的话 你会发现打印出来的是文件passwd的所有内容,而加了-n你就会发现出现上面的结果,因为搜索是搜索整个文件,所以除了搜索到匹配的行,还有那些没有匹配的行,所以都会被打印出来,但是如果你加了-n就只显示匹配的行

下面是复合命令

下面的命令是nl命令显示文本,用-n显示被处理的行,/ftp/是搜索ftp字符串,{s/nologin/bash/g;p}是把有ftp行里面的nologin替换成bash,并打印出来,注意,p是打印的意思,要用;分开

[root@controller ~]# nl passwd | sed -n ‘/ftp/{s/nologin/bash/g;p}‘

    10  ftp:x:14:50:FTP User:/var/ftp:/sbin/bash

除了整行的处理模式之外, sed 还可以用行为单位进行部分数据的搜寻并取代。基本上 sed 的搜寻与替代的与 vi 相当的类似!他有点像这样

sed ‘s/要被取代的字串/新的字串/g‘

下面是练习

[root@controller ~]# /sbin/ifconfig enp8s0 | grep netmask

        inet 192.168.100.10  netmask 255.255.255.0  broadcast 192.168.100.255

要求只要192.168.100.10其他的都不要,你要怎么做方法在下面





















[root@controller ~]# /sbin/ifconfig enp8s0 | grep netmask | awk -F ‘ ‘ ‘{print $2}‘

192.168.100.10

[root@controller ~]# ip=`/sbin/ifconfig enp8s0 | grep netmask | sed ‘s/netmask.*//‘ | sed ‘s/inet //‘`

[root@controller ~]# echo $ip

192.168.100.10

下面是多点编辑

一条sed命令,删除passwd第三行到末尾的数据,并把bash替换为blueshell

[root@controller ~]# nl /etc/passwd | sed -e ‘3,$d‘ -e ‘s/bash/blueshell/‘

     1  root:x:0:0:root:/root:/bin/blueshell

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

sed 可以直接修改文件的内容,不必使用管道命令或数据流重导向! 不过,由於这个动作会直接修改到原始的文件,所以请你千万不要随便拿系统配置来测试! 
如果你想删除文件配置信息的话,可以用下面命令 -i是指可以直接修改文件里面的东西

[root@controller ~]# sed -i ‘2d‘ passwd 

[root@controller ~]# sed -in ‘$a #this is test!‘ passwd

由於 $ 代表的是最后一行,而 a 的动作是新增,因此该文件最后新增『# This is a test』!

可以参考下面的网址:http://www.cnblogs.com/stephen-liu74/archive/2011/11/17/2245130.html

本文出自 “爱周瑜” 博客,请务必保留此出处http://izhouyu.blog.51cto.com/10318932/1914710

sed常用命令