sed命令详解

来源:互联网 发布:windows创建git服务器 编辑:程序博客网 时间:2024/06/14 11:38

  sed是一款出色的流编辑器,够完美的配合正则表达式使用,功能不同凡响。处理时,把当前处理的行存储在临时缓冲区中,称为“模式空间”(pattern space),接着用sed命令处理缓冲区中的内容,处理完成后,把缓冲区的内容送往屏幕。接着处理下一行,这样不断重复,直到文件末尾。文件内容并没有 改变,除非你使用重定向存储输出。Sed主要用来自动编辑一个或多个文件;简化对文件的反复操作;编写转换程序等。

1)sed用法:

sed [options] 'command'file(s)
sed [options] -f scriptfile file(s)

[options]:

  -e script :以脚本来处理输入的文本文件

  -f script:以脚本文件来处理输入的文本文件

  -n 使用安静或者沉默模式,默认的sed的输入文本都会打印到屏幕上,使用-n选项后经过sed处理过的文本才会打印到屏幕上

  -r :sed 支持是延伸型正规表示法的语法。(默认是基础正规表示法语法)

   -i :直接修改读取的文件内容,而不是输出到终端


command:

  a :新增, a 的后面可以接字串,而这些字串会在新的一行出现(目前的下一行)~
  c :取代, c 的后面可以接字串,这些字串可以取代 n1,n2 之间的行!
  d :删除,因为是删除啊,所以 d 后面通常不接任何咚咚;
  i :插入, i 的后面可以接字串,而这些字串会在新的一行出现(目前的上一行);
  p :列印,亦即将某个选择的数据印出。通常 p 会与参数 sed -n 一起运行~s :取代,可以直接进行取代的工作哩!通常这个 s 的动作可以搭配正规表示法!例如1,20s/old/new/g 就是啦!

2)sed替换标记:

  g 表示行内全面替换
  p 表示打印行  
   w 表示把行写入一个文件。 
  x 表示互换模板块中的文本和缓冲区中的文本。 
  y 表示把一个字符翻译为另外的字符(但是不用于正则表达式)
\1 子串匹配标记
& 已匹配字符串标记

3)sed结合正则表达式使用:

^ 匹配行开始,如:/^sed/匹配所有以sed开头的行。
$ 匹配行结束,如:/sed$/匹配所有以sed结尾的行。. 匹配一个非换行符的任意字符,如:/s.d/匹配s后接一个任意字符,最后是d。
* 匹配0个或多个字符,如:/*sed/匹配所有模板是一个或多个空格后紧跟sed的行。
[] 匹配一个指定范围内的字符,如/[ss]ed/匹配sed和Sed。 
[^] 匹配一个不在指定范围内的字符,如:/[^A-RT-Z]ed/匹配不包含A-R和T-Z的一个字母开头,紧跟ed的行。
\(..\) 匹配子串,保存匹配的字符,如s/\(love\)able/\1rs,loveable被替换成lovers。
& 保存搜索字符用来替换其他字符,如s/love/**&**/,love这成**love**。
\< 匹配单词的开始,如:/\<love/匹配包含以love开头的单词的行。
\> 匹配单词的结束,如/love\>/匹配包含以love结尾的单词的行。
x\{m\} 重复字符x,m次,如:/0\{5\}/匹配包含5个0的行。
x\{m,\} 重复字符x,至少m次,如:/0\{5,\}/匹配至少有5个0的行。
x\{m,n\} 重复字符x,至少m次,不多于n次,如:/0\{5,10\}/匹配5~10个0的行。

4)用法实例

(1)s命令

[root@B ~]# sed 's#coo#boo#' a.log
aook
book sdf
book sdf
dook sdf
boos sdf

-n和p命令结合使用,只打印经过处理后的行

[root@B ~]# sed -n 's#cook#book#p' a.log
book sdf
book sdf
boosk sdf

直接编辑文件选项-i

sed -i 's#cook#book#g'

(2)全面替换标记g

sed -i 's#cook#book#g' a.log

添加g会匹配输入文本的每一行

ng则表示从匹配到的第N处字符串进行处理

[root@B ~]# echo haha |sed 's#ha#HAHA#g'
HAHAHAHA
You have new mail in /var/spool/mail/root
[root@B ~]# echo haha |sed 's#ha#HAHA#1g'
HAHAHAHA
[root@B ~]# echo haha |sed 's#ha#HAHA#2g'
haHAHA
[root@B ~]# echo haha |sed 's#ha#HAHA#3g'
haha

(3)定界符

以上命令中字符 / 在sed中作为定界符使用,也可以使用任意的定界符:

sed 's:test:TEXT:g'sed 's|test|TEXT|g'

定界符出现在样式内部时,需要进行转义:

sed 's/\/bin/\/usr\/local\/bin/g'

(4)删除操作:d
删除空白行
[root@B ~]# sed  '/^$/d' a.log

删除第二行
[root@B ~]# sed  '2d' a.log

删除第三行到行尾
sed  '3,$d' a.log

删除最后一行
sed '$d' a.log

删除所有以coo开头的行
sed '/^co/d' a.log


(5)已匹配字符串标记&

echo "my ip:192.168.200.128" |sed 's/192.168.200.128/&:localhost/'
my ip:192.168.200.128:localhost

(6)已匹配到字符串标记\1\2\3...

 sed -i 's/\\n\(abc\)/\1/p' a.log


(7)组合多个表达式

sed '表达式' | sed '表达式'

等价于:

sed '表达式; 表达式'

(8)多点编辑

[root@B ~]# sed -e '2d' -e '/^coo/d' a.log

(9)\i \a追加

sed '/^boo/a\this is a test' a.log
aoo
boo
this is a test


 sed '/^boo/i\this is a test' a.log
aoo
this is a test
boo