Sed可以自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。
参数说明:
-e<script> | --expression=<script> | 以选项中指定的script来处理输入的文本文件 |
-f<script文件> | --file=<script文件> | 以选项中指定的script文件来处理输入的文本文件 |
-h | --help | 显示帮助 |
-n | --quiet | 仅显示script处理后的结果 |
-V | --version | 显示版本信息 |
动作说明:
a | 新增 | a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行) |
c | 取代 | c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行 |
d | 删除 | 因为是删除啊,所以 d 后面通常不接任何咚咚 |
i | 插入 | i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行) |
p | 打印 | 亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行 |
s | 取代 | 可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法 |
例:
在filename文件的第四行后添加一行,并将结果输出到标准输出:
sed -e 4a\newLine filename
删除第N行:
sed -i 'Nd' filename
删除第M到N行:
sed -i 'M,Nd' filename
删除a.txt中含"abc"的行,但不改变a.txt文件本身,操作之后的结果在终端显示
sed -e '/abc/d' a.txt
删除a.txt中含"abc"的行,将操作之后的结果保存到a.log
sed -e '/abc/d' a.txt > a.log
删除含字符串"abc"或“efg"的行,将结果保存到a.log
sed '/abc/d;/efg/d' a.txt > a.log
以行为单位的新增/删除
将 /etc/passwd 的内容列出并且列印行号,同时,请将第 2~5 行删除!
nl /etc/passwd | sed '2,5d'
要删除第 3 到最后一行
nl /etc/passwd | sed '3,$d'
在第二行后(亦即是加在第三行)加上『drink tea?』字样!
nl /etc/passwd | sed '2a drink tea'
如果是要增加两行以上,在第二行后面加入两行字,例如 Drink tea or ..... 与 drink beer?
~]# nl /etc/passwd | sed '2a Drink tea or ......\
> drink beer ?'
每一行之间都必须要以反斜杠『 \ 』来进行新行的添加喔!
以行为单位的替换与显示
将第2-5行的内容取代成为『No 2-5 number』呢?
nl /etc/passwd | sed '2,5c No 2-5 number'
列出 /etc/passwd 文件内的第 5-7 行
nl /etc/passwd | sed -n '5,7p'
数据的搜寻并显示
搜索 /etc/passwd有root关键字的行
nl /etc/passwd | sed '/root/p'
如果root找到,除了输出所有行,还会输出匹配行。
使用-n的时候将只打印包含模板的行。
nl /etc/passwd | sed -n '/root/p'
1 root:x:0:0:root:/root:/bin/bash
数据的搜寻并删除
删除/etc/passwd所有包含root的行,其他行输出
nl /etc/passwd | sed '/root/d'
数据的搜寻并执行命令
搜索/etc/passwd,找到root对应的行,执行后面花括号中的一组命令,每个命令之间用分号分隔,这里把bash替换为blueshell,再输出这行:
nl /etc/passwd | sed -n '/root/{s/bash/blueshell/;p;q}'
最后的q是退出。
数据的搜寻并替换
除了整行的处理模式之外, sed 还可以用行为单位进行部分数据的搜寻并取代。基本上 sed 的搜寻与替代的与 vi 相当的类似!他有点像这样:
sed 's/要被取代的字串/新的字串/g'
先观察原始信息,利用 /sbin/ifconfig 查询 IP
[root@www ~]# /sbin/ifconfig eth0
eth0 Link encap:Ethernet HWaddr 00:90:CC:A6:34:84
inet addr:192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
inet6 addr: fe80::290:ccff:fea6:3484/64 Scope:Link
UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
.....(以下省略).....
本机的ip是192.168.1.100。
将 IP 前面的部分予以删除
[root@www ~]# /sbin/ifconfig eth0 | grep 'inet addr' | sed 's/^.*addr://g'
192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
接下来则是删除后续的部分,亦即: 192.168.1.100 Bcast:192.168.1.255 Mask:255.255.255.0
将 IP 后面的部分予以删除
[root@www ~]# /sbin/ifconfig eth0 | grep 'inet addr' | sed 's/^.*addr://g' | sed 's/Bcast.*$//g'
192.168.1.100
多点编辑
一条sed命令,删除/etc/passwd第三行到末尾的数据,并把bash替换为blueshell
nl /etc/passwd | sed -e '3,$d' -e 's/bash/blueshell/'
1 root:x:0:0:root:/root:/bin/blueshell
2 daemon:x:1:1:daemon:/usr/sbin:/bin/sh
直接修改文件内容(危险动作)
利用 sed 将 regular_express.txt 内每一行结尾若为 . 则换成 !
[root@www ~]# sed -i 's/\.$/\!/g' regular_express.txt
[root@www ~]# cat regular_express.txt
runoob!
google!
taobao!
facebook!
zhihu-
weibo-
利用 sed 直接在 regular_express.txt 最后一行加入 # This is a test:
[root@www ~]# sed -i '$a # This is a test' regular_express.txt
由於 $ 代表的是最后一行,而 a 的动作是新增
sed 的 -i 选项可以直接修改文件内容