shell脚本之sed详解 (sed命令 , sed -e , sed s/ new / old / ... )
Posted zyh9900010
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了shell脚本之sed详解 (sed命令 , sed -e , sed s/ new / old / ... )相关的知识,希望对你有一定的参考价值。
(一)
Sed是一个非交互性文本流编辑器。它编辑文件或标准输入导出的文本拷贝。vi中的正则表达式命令在sed中大多可以通用。
##sed常用选项
-e script 指定sed编辑命令
-f scriptfile 指定的文件中是sed编辑命令
-n 寂静模式,抑制来自sed命令执行过程中的冗余输出信息,比如只显示那些被改变的行。
-i[SUFFIX], –in-place[=SUFFIX] 替换和备份源文件
edit files in place (makes backup if extension supplied)
##1. 参数p: 打印匹配行
$ sed -n ’2p’/etc/passwd 打印出第2行
$ sed -n ’1,3p’/etc/passwd 打印出第1到第3行
$ sed -n ‘$p’/etc/passwd 打印出最后一行
$ sed -n ‘/user/p’ /etc/passwd 打印出含有user的行
$ sed -n ‘/$/p’ /etc/passwd 打印出含有$元字符的行,$意为最后一行
$ sed -n ‘$=’ ok.txt 打印总行数
##2.参数a和i: 插入文本和附加文本(插入新行)
$ sed -n ‘/FTP/p’/etc/passwd 打印出有FTP的行
$ sed ‘/FTP/a 456′ /etc/passwd 在含有FTP的行后面新插入一行,内容为456
$ sed ‘/FTP/i 123′ /etc/passwd在含有FTP的行前面新插入一行,内容为123
$ sed ‘/FTP/i “123″’ /etc/passwd在含有FTP的行前面新插入一行,内容为”123″
$ sed ’5 a 123′ /etc/passwd 在第5行后插入一新行,内容为123
$ sed ’5 i “12345″’ /etc/passwd 在第5行前插入一新行,内容为”123表达式45″
sed-搜索结果后面增加嵌入代码
#!/bin/bash
#export LANG=zh_CN
find ./ -name “*.html” -exec grep 10000008/100 ‘{}’ ; -exec sed -i ‘/10000008/a<!--# include file="/code.html"-->‘ {} ;
#
##3.参数d:删除文本
删空格
sed -i ‘s/[ ]*//g’ ~/$cid.txt
删除无内容空行
sed ‘/^$/d’ file.conf > file.new.conf
sed -i ‘/^$/d’ ~/$cid.txt
删第一行
sed -i ’1d’ ~/$cid.txt
删前两行
sed -i ’1,2d’ ~/$cid.txt
del多行
cat SCTP.log |sed ’1d;2d;$d’
删除最后一行:
sed -e ‘$d’ file
删除最后两行:
sed ‘N;$!P;D’ file
sed ‘N;$!P;$!D;$d’ file
删除最后n行:
$vi sed.sh
$!/bin/bash
A=$(sed -n ‘$=’ file)
sed $(($A-n+1)),${A}d file
$ sed ‘/user/d’/etc/passwd
删除带有string的行(del include love row head)
sed -i ‘/^love/d’ file
sed -i ‘/love/d’ file
vi删除包含strings前4行,后34行
:/strings/-4,+34d
删除配置文件中#号注释行
sed ‘s##.*##’ file.conf > file.new.conf
sed ‘s,#.*,,’
删除配置文件中//号注释行
sed ‘s#//.*##’ file.conf > file.new.conf
sed ‘s@//.*@@’
删除由空格和Tab而成的空行
sed ‘/^[[:space:]]*$/d’ file.conf > file.new.conf
sed ‘/^[[:space:]]*$/d’
删除尾行的空格
sed -e ‘s/.$//’ file > file.new.conf
在尾行添加1个空格
sed ‘s/[0-9]$/& /g’ file > flile.new.conf
##4. 参数s:替换文本,替换命令用替换模式替换指定模式,格式为:
[ a d d r e s s [,address]] s/pattern-to-find/replacement-pattern/[g p w n]
$ sed ‘s/user/USER/’/etc/passwd 将第1个user替换成USER,g表明全局替换
$ sed ‘s/user/USER/g’/etc/passwd 将所有user替换成USER
$ sed ‘s/user/#user/’/etc/passwd 将第1个user替换成#user,如用于屏蔽作用
$ sed ‘s/user//’/etc/passwd 将第1个user替换成空
$ sed ‘s/user/&11111111111111/’/etc/passwd 如果要附加或修改一个很长的字符串,可以使用( &)命令,&命令保存发现模式以便重新调用它,然后把它放在替换字符串里面,这里是把&放前面
$ sed ‘s/user/11111111111111&/’/etc/passwd 这里是将&放后面 在包含字符串test的任意行上,将111替换成222
$ sed ‘/test/s/111/222/g’ sample.txt
##5. 快速一行正则表达式命令 下面是一些一行命令集。([ ]表示空格,[TAB]表示t a b键)
‘s/ . $//g’ 删除以句点结尾行
‘-e/abcd/d’ 删除包含a b c d的行
‘s/[ ] [ ] [ ] */[ ]/g’ 删除一个以上空格,用一个空格代替
‘s/^ [ ] [ ] *//g’ 删除行首空格
‘s/ . [ ] [ ] */[ ]/g’ 删除句点后跟两个或更多空格,代之以一个空格
‘/^ $/d’ 删除空行
‘s/^ .//g’ 删除第一个字符
‘s/COL ( . . . )//g’ 删除紧跟C O L的后三个字母
‘s/^ ///g’ 从路径中删除第一个‘s/[ ]/[TAB]//g’ 删除所有空格并用t a b键替代
‘S/^ [TAB]//g’ 删除行首所有t a b键
‘s/[TAB] *//g’ 删除所有t a b键
##6、用sed删除文件中的换行符,杀鸡哪需牛刀?
tr -d ‘
’ file
真的需要sed
sed -nr ‘ H;
$ {
x;
s/
//g;
p
}’
##7、sed获取ip
[root@c01 ~]# ifconfig eth0|sed -ne ‘s/^.*addr:([0-9.]*).*$/1/p’
192.168.100.180
[root@c01 ~]# ifconfig eth0 | sed -e ‘/inet/!d’ -e ‘s/.*addr://’ -e ‘s/[ ].*//’
192.168.100.180
##8、/转义字符
echo /usr/local/bin | sed ‘s//usr/local/bin//common/bin/’
find . -name “*.html” |xargs sed -i ‘s#/canApp/evaluation/html/ index.html#http://www.wallcopper.com/eva/#g’
都可以把当前目录下的.c .h文件中的TAB替换成4个空格。
find . -name “*.[c|h]” | xargs sed -i ‘s/ / /g’
##9、参数f:
以下三个命令相等,先在包含字符串test的任意行上,将111替换成222,再将字符f替换成hello
$ sed ‘/test/s/111/222/g ; s/f/hello/g’ sample.txt
$ sed -e ‘/test/s/111/222/g’ -e ‘s/f/hello/g’ sample.txt
选项-f: 将要执行的所以编译命令放入在文件中
$ more scher
/test/s/111/222/g
s/f/hello/g’ sample.txt
$ sed -f scher sample.txt
##10、参数q: 表示跳离sed。最多与一个地址参数配合。
打印出含有a或b字符的行,一旦遇到数字,即刻停止打印。
$ sed -n -e ‘/[0-9]/q’ -e ‘/[a b]/p’
到china quit
sed ‘china/q’ myfile.txt
##11、参数-i后缀:替换并将源文件备份改后缀
$ sed -i.bak ‘s/123/efg/g’ a.txt 备份源文件
##12、参数r:在某行插入文件
$ sed -i ’2 r readfile.txt’ writefile.txt
##13、参数w:读入文件中的内容存入到另一文件中(temp.txt)。最多与一个地址参数配合。
将sample.txt文件中含test字符串的数据行,copy至temp.txt档中储存(原temp.txt中无内容)
$ sed -e ‘/test/w temp.txt’ sample.txt
##14、参数y:转换数据中的字符。最多与两个地址参数配合。
1.将文件中的小写字母替换成大写字母。
$ sed -e ‘y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/’ sample.txt
其中前后字符个数必须相同.
##15、参数!:表示不执行函数参数。 将文件中除了important字符串,其余全删除。
$ sed -e ‘/important/!d’ sample.txt
##16、参数=:表示印出资料的行数。最多与两个地址参数配合。 1.印出文件资料并显示行数。
$ sed -e ‘=’ sample.txt
计算总行数
$ sed -n ‘$=’ a.txt
##17、其它参数 参数#:表示对文字的注释。
参数N:表示添加下一笔资料到pattern space内。最多与两个地址参数配合。(添加下一笔:添加一笔资料后,继续添加这个资料的下一行数据到pattern space内) 1,将文件中的数据合并。文件内容如下: UNIX LINUX
$ sed -e ‘N’ -e’s/
/,/g’ sample.txt
结果如下: UNIX,LINUX
参数D:表示删除pattern space内的第一行资料。最多与两个地址参数配合。
参数P:打印出pattern space内的第一行资料。
$ sed -n -e ‘N’ -e ‘P’ sample.txt
利用N将下一行资料(即:偶数行)添加到pattern space内,在利用P打印出奇数行。 解释过程:由于N的作用,使得每次添加一条资料到pattern space后,先不执行操作,而是继续添加这个资料的下一行到pattern space内, 然后P参数打印出第一行资料。
参数h:表示暂存pattern space的内容至hold space(覆盖)。最多与两个地址参数配合。
参数H:表示暂存pattern space的内容至hold space(添加)。最多与两个地址参数配合。
参数g:表示将hold space的内容放回至pattern space内。(覆盖掉原pattern space内的数据)
参数G:表示将hold space的内容放回至pattern space内。(添加大到原pattern space数据之后)
将文件中所有空行删除,并在每一行后面增加一个空行。
$ sed ‘/^$/d;G’ sample.txt
将文件中所有空行删除,并在每一行后面增加两个空行。
$ sed ‘/^$/d;G;G’ sample.txt
参数x:表示交换hold space与pattern space内的数据。
将文件第三行的数据替换成第一行的数据。
$ sed -e ’1h’ -e ’3x’ sample.txt
参数b:
参数t:
如果使用sed对文件进行过滤,最好将问题分成几步,分步执行,且边执行边测试结果。
经验告诉我们,这是执行一个复杂任务的最有效方式。
参考:
http://www.2cto.com/os/201111/112217.html
http://markmail.org/download.xqy?id=w5pncjwnrs77lz3s&number=2
http://www.grymoire.com/Unix/Sed.html
http://sed.sourceforge.net/sed1line.txt
转自:
http://www.wallcopper.com/linux/769.html
( 二 )
一, 基本概述
(1)基本介绍
sed是一款流编辑工具,用来对文本进行过滤与替换工作, sed通过输入读取文件内容,但一次仅读取一行内容进行某些指令处理后输出,sed更适合于处理大数据文件。
(2)工作原理
sed在处理文本文件的时候,会在内存上创建一个模式空间,然后把这个文件的每一行调入模式空间用相应的命令处理,处理完输出;接着处理下一行,直到最后。
(3)与vim的区别
vim需要通知处理文件的哪几行才会去处理,sed默认会处理文件的所有行,除非你告诉它不处理哪几行。
二, sed的基本语法
(1)sed [选项] [定址commands] [inputfile]
关于定址:
定址可以是0个、1个、2个;通知sed去处理文件的哪几行。
0个:没有定址,处理文件的所有行
1个:行号,处理行号所在位置的行
2个:行号、正则表达式,处理被行号或正则表达式包起来的行
(2)
选项:
--version 显示sed版本hao
--help 显示帮助文档
-n 关闭默认输出,默认将自动打印所有行
-e 多点编辑,允许多个脚本指令被执行。
-r 支持扩展正则+ ? () {} |
-i 可以修改原文件,慎用!
-f 支持使用脚本
命令:
p打印行
d 删除行
s 替换
n替换第几个匹内容
w另存为
a 之后添加一行
i 当前行之前插入文本
y 替换匹配内容
三, 实际案例讲解
(1)p(与-n合用)
查看passwd文件的1~3行
@1,打印一到三行
[root@tx3 ~]# cp /etc/passwd /t1
[root@tx3 ~]# cat -n t1 | sed -n ‘1,3p‘
1root:x:0:0:root:/root:/bin/bash
2bin:x:1:1:bin:/bin:/sbin/nologin
3daemon:x:2:2:daemon:/sbin:/sbin/nologin
@2,查看passwd文件的lp~halt行
[root@tx3 ~]# cat -n t1 |sed -n ‘/lp/,/halt/p‘
5lp:x:4:7:lp:/var/spool/lpd:/sbin/nologin
6sync:x:5:0:sync:/sbin:/bin/sync
7shutdown:x:6:0:shutdown:/sbin:/sbin/shutdown
8halt:x:7:0:halt:/sbin:/sbin/halt
@3, 打印基数行(从第一行开始,每隔一行一输出)
@4,打印uid是0或1的行
[root@tx3 ~]# sed -n ‘/x:[01]:/p‘ t1
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
(2)d 删除
@1,删除第一行
@2,删除第一行和第三行(与-e选项合用)
@3,;选项的使用和-e一样
@4,取反:!
[root@tx3 ~]# cat -n t1 | sed ‘1!d‘
1root:x:0:0:root:/root:/bin/bash
(3)s 查找替换 s///
语法:
‘[address]s/pattern/replacement/flags‘
old new
flags:
n:1-512 之间的正整数,表示替换模式里面出现的第几次内容
p:打印
g:全局修改
w:另存为
这几个选项是可以复合使用的,但是写的要有意义。(pg ;nw)
注:这里为部分截取
@1默认会替换行里面的第1个匹配
[root@tx3 ~]# sed ‘s/root/ROOT/‘ t1
ROOT:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
@2全部替换
[root@tx3 ~]# sed ‘s/root/ROOT/g‘ t1
ROOT:x:0:0:ROOT:/ROOT:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
@3替换第2个匹配
[root@tx3 ~]# sed ‘s/root/ROOT/2‘ t1
root:x:0:0:ROOT:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
@4打印
[root@tx3 ~]# sed ‘s/root/ROOT/p‘ t1
ROOT:x:0:0:root:/root:/bin/bash
ROOT:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin‘
[root@tx3 ~]# sed -n ‘s/root/ROOT/p‘ t1
ROOT:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/ROOT:/sbin/nologin
@5另存为
[root@tx3 ~]# sed -n ‘s/root/ROOT/w /tx‘ t1
[root@tx3 ~]# cat /tx
ROOT:x:0:0:root:/root:/bin/bash
operator:x:11:0:operator:/ROOT:/sbin/nologin
@6在文件的每行前面添加 # 注释
[root@tx3 ~]# sed ‘s/^/#/‘ t1
#root:x:0:0:root:/root:/bin/bash
#bin:x:1:1:bin:/bin:/sbin/nologin
#daemon:x:2:2:daemon:/sbin:/sbin/nologin
@7删掉文件的第1个字符
[root@tx3 ~]# sed ‘s/^.//1‘ t1
oot:x:0:0:root:/root:/bin/bash
in:x:1:1:bin:/bin:/sbin/nologin
aemon:x:2:2:daemon:/sbin:/sbin/nologin
@8删掉文件的第2个字符
[root@tx3 ~]# sed ‘s/.//2‘ t1
rot:x:0:0:root:/root:/bin/bash
bn:x:1:1:bin:/bin:/sbin/nologin
(4)i 从当前行插入
在第一行前插入hello
[root@tx3 ~]# sed ‘1i hello‘ t1
hello
root:x:0:0:root:/root:/bin/bash
bin:x:1:1:bin:/bin:/sbin/nologin
(5)a 从当前行后添加
在第一行后添加hello
[root@tx3 ~]# sed ‘1a hello‘ t1
root:x:0:0:root:/root:/bin/bash
hello
bin:x:1:1:bin:/bin:/sbin/nologin
(6)-r 支持扩展正则
[root@tx3 ~]# sed -r ‘s/^(.)(.)/1/‘ t1
rot:x:0:0:root:/root:/bin/bash //相当于把前两个字符替换成第一个字符,这样就实现了删除第二个字符
bn:x:1:1:bin:/bin:/sbin/nologin
demon:x:2:2:daemon:/sbin:/sbin/nologin
其他方法:
@1#sed ‘s/.//2‘ t1
@2#sed ‘s/^..../1/‘ t1
(7)y 替换,按照位置来匹配替换 y/// 不识别re
[root@tx3 ~]# sed ‘y/abcdefghijklmnopqrstuvwxyz/ABCDEFGHIJKLMNOPQRSTUVWXYZ/‘ t1
ROOT:X:0:0:ROOT:/ROOT:/BIN/BASH
BIN:X:1:1:BIN:/BIN:/SBIN/NOLOGIN
DAEMON:X:2:2:DAEMON:/SBIN:/SBIN/NOLOGIN
(8)替换匹配行
@1[root@tx3 ~]# sed -n ‘1c ROOT‘ t1
ROOT
(9)q 退出
[root@tx3 ~]# sed ‘1q ‘ t1
root:x:0:0:root:/root:/bin/bash
(10)-i 可以修改原文件
(11)-f 支持脚本
四.sed如何处理数据
PATT:模式空间,处理文件的输入行,处理文件的空间,最多保存8192字节,相当于车间sed把流内容在这里处理。
HOLD:保留空间,用来保存已经处理的输入行;最多保存8192字节;默认有一个空行,相当于仓库,加工的半成品在这里临时储存。
COMM:命令
h:将模式空间里的内容,复制到保留空间里,覆盖原来的内容 >
H:将模式空间里的内容,追加到保留空间里,保留原来的内容 >>
g:将保留空间里的内容,复制到模式空间里,覆盖原来的内容
G:将保留空间里的内容,追加到模式空间里,保留原来的内容
n:对匹配行的下一行进行处理
x:交换模式空间和保留空间的内容
(1)h;G
@1.将第一行的内容放到打三行后面
@2.在每行的后面添加1个空行
注:1.保留空间里默认有一个空白行。2,‘G’默认处理全局
@3.把第1行到第4行的数据复制到第5行后面
注:1h是为了覆盖保留空间里的空白行
@4. 把第1行到第4行的数据剪切到第5行后面
(2)n 对匹配行的下一行进行处理
(3)x 交换模式空间和保留空间的内容
以上是关于shell脚本之sed详解 (sed命令 , sed -e , sed s/ new / old / ... )的主要内容,如果未能解决你的问题,请参考以下文章