Sed本身是一个管道命令,可以剖析 standard input 的,紧张是用来剖析关键字的利用、统计等,此外还可 以将数据进行更换、删除、选中、选取特定行等功能
语法sed [options] ‘{command}[flags]’ [filename] # 中括号内容必有 大括号内容可有可无sed # 实行命令[options] # 命令选项{command}[flags] # sed内部选项和参数[filename] # 文件
参数
命令选项-e script 将脚本中指定的命令添加到处理输入时实行的命令中 多条件,一行中要有多个操作-f script 将文件中指定的命令添加到处理输入时实行的命令中-n 抑制自动输出-i 编辑文件内容-i.bak 修正时同时创建.bak备份文件。-r 利用扩展的正则表达式! 取反 (跟在模式条件后与shell有所差异)sed常用内部命令a 在匹配后面添加i 在匹配前面添加p 打印d 删除s 查找更换c 变动y 转换 N D P flags数字 表示新文本更换的模式g: 表示用新文本更换现有文本的全部实例p: 表示打印原始的内容w filename: 将更换的结果写入文件
sed结合正则利用
sed 选项 ‘sed命令或者正则表达式或者地址定位’ 文件名
正则

解释
备注
/key/
查询包含关键字的行
sed -n ‘/root/p’ 1.txt
/key1/,/key2/
匹配包含两个关键字之间的行
sed -n ‘/^adm/,/^mysql/p’ 1.txt
/key/,x
从匹配关键字的行开始到文件第x行之间的行(包含关键字所在行)
sed -n ‘/^ftp/,7p’
x,/key/
从文件的第x行开始到与关键字的匹配行之间的行
x,y!
不包含x到y行
/key/!
不包括关键字的行
sed -n ‘/bash$/!p’ 1.txt
利用实例对sed命令大家要把稳,sed所做的修正并不会直接改变文件的内容(如果是用管道符吸收的命令的输出,这种情形连文件都没有),而是把修正结果只显示到屏幕上,除非利用“-i”选项才会直接修正文件。
提取行数据我们举几个例子来看看sed命令到底是干嘛的。假设我想查看下student.txt的第二行,那么就可以利用“p”动作了:
[root@localhost ~]$ sed '2p' student.txtID Name php Linux MySQL Average1 AAA 66 66 66 662 BBB 77 77 77 773 CCC 88 88 88 88
指定输出某行,利用-n选项
[root@localhost ~]$ sed -n '2p' student.txt1 AAA 66 66 66 66
删除行数据
[root@localhost ~]$ sed '2,4d' student.txt#删除第二行到第四行数据
追加插入行数据
[root@localhost ~]$ sed '2a hello' student.txt#在第二行后加入 hello
“a”会在指定行后面追加入数据,如果想要在指定行前面插入数据,则须要利用“i”动作:
[root@localhost ~]$ sed '2i hello world' student.txt#在第二行前插入两行数据
如果是想追加或插入多行数据,除末了一行外,每行的末端都要加入“\”代表数据未完结。再来看看“-n”选项的浸染:
[root@localhost ~]$ sed -n '2i hello world' student.txt#只查看sed命令操作的数据
更换行数据
“-n”只查看sed命令操作的数据,而不是查看所有数据。再来看看如何实现行数据更换,假设AAA的成绩太好了,我实在是不想看到他的成绩刺激我,那就可以利用"c"动作:
[root@localhost ~]$ cat student.txt | sed '2c No such person'
sed命令默认情形是不会修正文件内容的,如果我确定须要让 sed命令直接处理文件的内容,可以利用“-i”选项。不过要小心啊,这样非常随意马虎误操作,在操作系统文件时请小心谨慎。可以利用这样的命令:
[root@localhost ~]$ sed -i '2c No such person' student.txt
字符串更换
“c”动作是进行整行更换的,如果仅仅想更换行中的部分数据,就要利用“s”动作了。g 使得 sed 对文件中所有符合的字符串都被更换, 修正后内容会到标准输出,不会修正原文件。
[root@localhost ~]$ sed 's/旧字串/新字串/g' 文件名[root@localhost ~]$ sed '行范围s/旧字串/新字串/g' 文件名
更换的格式和vim非常类似,假设我以为我自己的PHP成绩太低了,想作弊给他改高点,就可以这样来做:
[root@localhost ~]$ sed '3s/74/99/g' student.txt#在第三行中,把74换成99
这样看起来就比较爽了吧。如果我想把AAA老师的成绩注释掉,让他不再生效。可以这样做:
[root@localhost ~]$ sed '2s/^/#/g' student.txt#这里利用正则表达式,“^”代表行首
在sed中只能指定行范围,以是很遗憾我在他们两个的中间,不能只把他们两个注释掉,那么我们可以这样:
[root@localhost ~]$ sed -e 's/AAA//g ; s/BBB//g' student.txt#同时把“Liming”和“Tg”更换为空
“-e”选项可以同时实行多个sed动作,当然如果只是实行一个动作也可以利用“-e”选项,但是这时没有什么意义。还要把稳,多个动作之间要用“;”号或回车分割,例如上一个命令也可以这样写:
[root@localhost ~]$ sed -e 's/Liming//g>s/Tg//g'’ student.txt
其他实例
1、正则表达式必须以”/“前后规范间隔例如:sed '/root/d' file例如:sed '/^root/d' file2、如果匹配的是扩展正则表达式,须要利用-r选来扩展sedgrep -Esed -r+ ? () {n,m} | \d把稳:在正则表达式中如果涌现分外字符(^$./[]),须要以前导 "\" 号做转义eg:sed '/\$foo/p' file3、逗号分隔符例如:sed '5,7d' file 删除5到7行例如:sed '/root/,/ftp/d' file 删除第一个匹配字符串"root"到第一个匹配字符串"ftp"的所有行本行不找 循环实行4、组合办法例如:sed '1,/foo/d' file 删除第一行到第一个匹配字符串"foo"的所有行例如:sed '/foo/,+4d' file 删除从匹配字符串”foo“开始到其后四行为止的行例如:sed '/foo/,~3d' file 删除从匹配字符串”foo“开始删除到3的倍数行(文件中)例如:sed '1~5d' file 从第一行开始删每五行删除一行例如:sed -nr '/foo|bar/p' file 显示配置字符串"foo"或"bar"的行例如:sed -n '/foo/,/bar/p' file 显示匹配从foo到bar的行例如:sed '1~2d' file 删除奇数行例如:sed '0-2d' file 删除偶数行 sed '1~2!d' file5、分外情形例如:sed '$d' file 删除末了一行例如:sed '1d' file 删除第一行6、其他:sed 's/.//' a.txt 删除每一行中的第一个字符sed 's/.//2' a.txt 删除每一行中的第二个字符sed 's/.//N' a.txt 从文件中第N行开始,删除每行中第N个字符(N>2)sed 's/.$//' a.txt 删除每一行中的末了一个字符