-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