Linux sed 命令是利用脚本处理文本文件。
sed 可按照脚本的指令来处理、编辑文本文件。
sed 主要用于自动编辑一个或多个文件、简化对文件的反复操作、编写转换程序等。
语法:
sed [-hnV][-e<script>][-f<script文件>][文本文件]
参数说明:
-e <script>或--expression=<script> 以选项中指定的script来处理输入的文本文件。 -f <script文件>或--file=<script文件> 以选项中指定的script文件来处理输入的文本文件。 -h 或--help 显示帮助。 -n 或--quiet或--silent 仅显示script处理后的结果。 -V 或--version 显示版本信息。
动作说明:
a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~ c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行! d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚; i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行); p :打印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~ s :取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如 1,20s/old/new/g 就是啦!
元字符集:
^ 指定行的开始 $ 指定行的结尾 . 匹配一个非换行符的字符 * 匹配零个或多个字符 [] 匹配指定字符内的任一字符 [^] 匹配不在指定字符内的任一字符 .. 保存已匹配的字符 & s/super/YY&yy/ super变成YYsuperyy & 保存搜索字符用来替换其他字符 < 词首定位符 /<my/ 匹配包含以my开头的单词的行 > 词尾定位符 /my>/ 匹配包含以my结尾的单词的行 x{m} 连续m个x /9{5}/ 匹配包含连续5个9的行 x{m,} 至少m个x /9{5,}/ 匹配包含至少连续5个9的行 x{m,n} 至少m个,但不超过n个x /9{5,7}/ 匹配包含连续5到7个9的行
实例:
在testfile文件第四行后添加一行,并将结果输出到标准输出,在命令行提示符输入如下命令:
sed -e 4ahellowolrd testfile
查看testfile 中的内容:
[root@127-0-0-1 yoon]# cat testfile.txt HELLO LINUX! Linux is a free unix-type opterating system. This is a linux testfile! good good study! Linux test
使用sed命令后,输出结果如下:
[root@127-0-0-1 yoon]# sed -e 4ahelloworld testfile.txt HELLO LINUX! Linux is a free unix-type opterating system. This is a linux testfile! good good study! helloworld Linux test
[root@127-0-0-1 yoon]# sed -e '4ahello world' testfile.txt (有空格需要单引号) HELLO LINUX! Linux is a free unix-type opterating system. This is a linux testfile! good good study! hello world Linux test
以行为单位的新增和删除
删除
将testfile的内容列出并且打印行号,同时删除第4-5行删除
[root@127-0-0-1 yoon]# nl testfile.txt 1 HELLO LINUX! 2 Linux is a free unix-type opterating system. 3 This is a linux testfile! 4 good good study! 5 hello world 6 Linux test [root@127-0-0-1 yoon]# nl testfile.txt | sed '4,5d' 1 HELLO LINUX! 2 Linux is a free unix-type opterating system. 3 This is a linux testfile! 6 Linux test
sed的动作为'4,5d',d是删除,因为4-5行删除了,所以显示的数据没有4-5行,另外,原本应该要下达 sed -e 才对,没有 -e 也可以。同事注意,sed 后面接的动作,务必以 '' 两个单引号扩住。
只删除第二行:
[root@127-0-0-1 yoon]# nl testfile.txt | sed '2d' 1 HELLO LINUX! 3 This is a linux testfile! 4 good good study! 5 hello world 6 Linux test
删除第三行到最后一行:
[root@127-0-0-1 yoon]# nl testfile.txt | sed '3,$d' ($代表最后一行) 1 HELLO LINUX! 2 Linux is a free unix-type opterating system.
新增
在第二行后面加上drink milk 字样(亦即是加在第三行):
[root@127-0-0-1 yoon]# nl testfile.txt | sed '2a drink milk' 1 HELLO LINUX! 2 Linux is a free unix-type opterating system. drink milk 3 This is a linux testfile! 4 good good study! 5 hello world 6 Linux test
如果加入到第二行前:
[root@127-0-0-1 yoon]# nl testfile.txt | sed '2i drink milk' 1 HELLO LINUX! drink milk 2 Linux is a free unix-type opterating system. 3 This is a linux testfile! 4 good good study! 5 hello world 6 Linux test
如果是增加两行以上,在第二行后面加入两行字,例如,drink milk,eat pig :
[root@127-0-0-1 yoon]# nl testfile.txt | sed '2a drink milk (每一行之间都必须要以反斜杠『 』来进行新行的添加) > eat pig' 1 HELLO LINUX! 2 Linux is a free unix-type opterating system. drink milk eat pig 3 This is a linux testfile! 4 good good study! 5 hello world 6 Linux test [root@127-0-0-1 yoon]# nl testfile.txt | sed '2a drink milk eat pig' ( 换行符) 1 HELLO LINUX. 2 This is a linux testfile. drink milk eat pig 3 good good study. 4 hello world. 5 Linux test. 6 #This is good !
追加一行的话,不需要换行符 ,只有追加多行的情况下才需要换行符,最后一行也无需添加换行符,添加的话会多出一个空格
在第四行添加一行:
[root@127-0-0-1 yoon]# sed -e '4a new world' testfile.txt HELLO LINUX. This is a linux testfile. good good study. hello world. new world Linux test. #This is good !
在第四行追加两行:
[root@127-0-0-1 yoon]# sed -e '4a new world old world' testfile.txt HELLO LINUX. This is a linux testfile. good good study. hello world. new world old world Linux test. #This is good !
在第四行追加三行(两行文字和一行空格):
[root@127-0-0-1 yoon]# sed -e '4a new world old world ' testfile.txt HELLO LINUX. This is a linux testfile. good good study. hello world. new world old world Linux test. #This is good !
添加一个空行:
[root@127-0-0-1 yoon]# sed -e '4a \' testfile.txt HELLO LINUX. This is a linux testfile. good good study. hello world. Linux test. #This is good !
[root@127-0-0-1 yoon]# sed -e '4a \n' testfile.txt
HELLO LINUX.
This is a linux testfile.
good good study.
hello world.
Linux test.
#This is good !
以行为单位的替换和显示
将第3-4行替换为 No 2-5 number
[root@127-0-0-1 yoon]# nl testfile.txt | sed '2,5c No 2-5 number' (通过这个方法可以取代整行) 1 HELLO LINUX! No 2-5 number 6 Linux test
仅列出第2-3行:
[root@127-0-0-1 yoon]# nl testfile.txt | sed -n '2,3p' 2 Linux is a free unix-type opterating system. 3 This is a linux testfile!
数据的搜寻并显示
搜索 linux 关键字的行:
[root@127-0-0-1 yoon]# nl testfile.txt | sed '/linux/p' (如果linux找到,除了输出所有行,还会匹配输出行) 1 HELLO LINUX! 2 Linux is a free unix-type opterating system. 3 This is a linux testfile! 3 This is a linux testfile! 4 good good study! 5 hello world 6 Linux test
使用 -n 的时候只输出包含模板的行
[root@127-0-0-1 yoon]# nl testfile.txt | sed -n '/linux/p' 3 This is a linux testfile!
数据的搜寻并删除
删除testfile中包含linux的行,其他行输出:
[root@127-0-0-1 yoon]# nl testfile.txt | sed '/linux/d' 1 HELLO LINUX! 2 Linux is a free unix-type opterating system. 4 good good study! 5 hello world 6 Linux test
数据的搜寻并执行命令
搜索 linux 对应的行,执行花括号中的命令,每个命令用分号分隔,并把 testfile 替换成 newtestfile,再输出这行:
[root@127-0-0-1 yoon]# nl testfile.txt | sed -n '/linux/{s/testfile/newtestfile/;p;q}' (最后的 q 是退出) 3 This is a linux newtestfile!
数据的搜寻并替换
除了整行的处理模式之外,sed 还可以用行为单位进行部分数据的搜寻并替换,基本上 sed 的搜寻与替代的 vi 相当的类似,有点像这样:
sed 's/要被取代的字符串/新的字符串/g'
查看 newtestfile 文件内容:
[root@127-0-0-1 yoon]# cat newtestfile.txt 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@127-0-0-1 yoon]# cat newtestfile.txt | 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@127-0-0-1 yoon]# cat newtestfile.txt | grep 'inet addr:' | sed 's/^.*addr://g' | sed 's/Bcast.*$//g' 192.168.1.100
多点编辑命令
sed -e 'cmd' -e 'cmd' filename
一条 sed 命令,将第三行到末尾的数据删除,并将opterating替换成 newopterating:
[root@127-0-0-1 yoon]# nl testfile.txt 1 HELLO LINUX! 2 Linux is a free unix-type opterating system. 3 This is a linux testfile! 4 good good study! 5 hello world 6 Linux test
多条sed: [root@127-0-0-1 yoon]# nl testfile.txt | sed '3,$d' | sed 's/opterating/newopterating/' 1 HELLO LINUX! 2 Linux is a free unix-type newopterating system.
一条sed: [root@127-0-0-1 yoon]# nl testfile.txt | sed -e '3,$d' -e 's/opterating/newopterating/' 1 HELLO LINUX! 2 Linux is a free unix-type newopterating system. ( -e 表示多点编辑,第一个 -e 编辑第三行到最后一行删除,第二个 -e 搜索 opterating替换成 newopterating)
直接修改文件内容
将 testfile 文件中的每一行结尾为 . 修改为 !:
[root@127-0-0-1 yoon]# cat testfile.txt HELLO LINUX. This is a linux testfile. good good study. hello world. Linux test. [root@127-0-0-1 yoon]# sed 's/.$/!/g' testfile.txt HELLO LINUX! This is a linux testfile! good good study! hello world! Linux test!
利用 sed 直接在最后一行输入 #This is good !
[root@127-0-0-1 yoon]# sed -i '$a #This is good !' testfile.txt [root@127-0-0-1 yoon]# cat testfile.txt HELLO LINUX. This is a linux testfile. good good study. hello world. Linux test. #This is good !