现在的位置: 首页 > 综合 > 正文

linux sed命令详解

2012年10月13日 ⁄ 综合 ⁄ 共 1894字 ⁄ 字号 评论关闭

Sed是一个非交互性上下文编辑器,它被设计用来在以下环境中发挥作用:

1.    可以直接操作或编辑那些对常规编辑器而言太大的文件。相信很多人都有过打打开一个大文件会拖死你的电脑的情况;

2.    编辑命令太复杂(windows上貌似不存在这种情况,用命令行的linux就难说了)很难以在交互模式下编辑文件;

3.    要在对输入的一趟扫描中有效的进行多个全局’(global)编辑函数

在开始介绍sed的控制符与语法之前,先概述几个概念:

  • 四个空间:input stream, pattern buffer, output stream hold buffer
  • 基本操作过程:将 input stream 的当前行放入 pattern buffer, 然后 input stream 的指针指向下一行 ; pattern buffer 中的行进行处理 ;将上面的处理结果放入 output stream. 然后循环这个过程 .
  • hold buffer 是另一个空间 , 可以通过命令和 pattern buffer 进行交互 .

Sed命令介绍:

一: 基本命令:字符串替换:’s’

1.    基本用法:
e.g.  sed ‘s/day/night/’ <old >new
该例子将文件 old 中的每一行第一次出现的 day 替换成 night, 将结果输出到文件 new
对上述例子的说明:
s            表示替换命令
/../../ 分割符 (Delimiter),第一个/../表示要搜索的字符或正则表达式,也就是上面例子中的’day’;第二个/../表示要用来替换的字符串,也就是上面例子中的’night’

2.    & 表示匹配的字符串
有时可能会想在匹配到的字符串周围或附近加上一些其它的字符,那么可以像下面这样来操作:
sed s/abc/(abc)/ <old >new
该例子从old文件中读取字符,在找到的 abc 前后加上括号,然后协会到文件new。该例子还可以写成
sed ‘s/abc/(&)/’ <old >new #效果和上面的一样
下面是更复杂的例子 :
sed ‘s/[a-z]*/(&)/’ <old >new
sed ‘s/[0-9]*/& &/’ <old >new

3.    /1, /2, …, /9 来表示匹配的字符串
先看个例子:
sed ‘s//([a-z]*/)[0-9]*//1/’ <old >new  #本例中 /1 就是指前面的 /([a-z]*/)
#如果在old文件中有内容:abc123 abc123那么在new文件中将会是:abc abc

/1, /2, …, /9 也可以出现在搜索字符串中,例如:
sed ‘s//([a-z]*/) /1//1/’ <old >new #本例可以去除重复的由字母组成的词

  1. 替换选项
    1.4.1 /g 替换所有
    sed 默认只替换搜索字符串的第一次出现 , 利用 /g 可以替换搜索字符串所有出现的地方, 例如:
    sed ‘s//([^ ]*/)/(&)/g’ <old >new

1.4.2  /1, /2, … 来表明替换哪一次出现
sed ‘s/[^ ]*//2′ <old >new #替换搜索到的第二次出现,可以从 /1 用到 /512

1.4.3  /p print 选项
sed 命令有 -n 选项时 , 该命令没有输出,例如,
sed -n ‘s//([a-z]*/)[0-9]*//1/’ <old #
如果old中包含内容:abc123,如果没有-n选项,则输出abc;有-n则不输出
但是如果-n 配合 /p 选项后, 如果该行确实发生了替换 , 则输出该行, 否则不输出。

1.4.4 /w filename’ 输出写到文件 filename
sed ‘s//([0-9]*/) /([a-z]*/)//2/w new’ <old
该例子把输出放入文件 new

5.   替换和插入换行符号
替换 (echo a;echo x;echo y) | sed ‘/x$/ {
N
s:x/n:x:
}’
上面的脚本输出:
a
xy
插入
(echo a;echo x;echo y) | sed ‘s:x:X/
:’
这条语句结果为:
a
x y

 

sed ‘s//([^ ]*/)/(&)/g’ <old >newsed ‘s//([^ ]*/)/(&)/g’ <old >new

二:只对特定行的处理

1.    通过行号限定

sed ‘3 s/[0-9][0-9]*//’ <old >new 只处理第 3

sed ’1,100 s/A/a/’ <old >new 只处理 1 100
sed ’101,$ s/A/a/’ <old >new 处理 101 到文件的最后一行
sed ’101,$ !s/A/a/’ <old >new 这里 ! 表示只对 1 100 行进行替换 ,! 作用 是取反

2. 通过正规表达式限定

sed ‘/start/,/stop/ s/#.*//’ <old >new
本例中 ,sed 先找到有 start 的行作为开始 ,

抱歉!评论已关闭.