Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2553763
  • 博文数量: 709
  • 博客积分: 12251
  • 博客等级: 上将
  • 技术积分: 7905
  • 用 户 组: 普通用户
  • 注册时间: 2005-07-17 00:00
个人简介

实现有价值的IT服务

文章存档

2012年(7)

2011年(147)

2009年(3)

2008年(5)

2007年(74)

2006年(431)

2005年(42)

sed

分类: IT职场

2005-10-29 10:57:39

sed使用手册(转载) 

sed使用手册(转载)
发信站: BBS 水木清华站 (Wed Sep 25 21:06:36 2002), 站内信件
 
 
 
  Sed 命令列可分成编辑指令与文件档部份。其中 , 编辑指令负责控制所有的编
辑工作 ; 文件档表示所处理的档案。 
  sed 的编辑指令均由位址(address)与函数(function)两部份组成 , 其中 , 在
执行时 , sed 利用它的位址参数来 
  决定编辑的对象;而用它的函数参数(解[3])编辑。  
  此外 , sed 编辑指令 , 除了可在命令列上执行 , 也可在档案内执行。其中差
别只是在命令列上执行时 , 其前必 
  须加上选项 -e ; 而在档案(解[4])内时 , 则只需在其档名前加上选项 -f。另
外 , sed 执行编辑指令是依照它 
  们在命令列上或档内的次序。  
 
  下面各节 , 将介绍执行命令列上的编辑指令 、sed 编辑指令、执行档案内的编
辑指令、执行多个档案的编辑、及 
  执行 sed 输出控制。  
 
2.1 执行命令列上的编辑指令  
2.2 sed 编辑指令  
2.3 执行档案内的编辑指令  
2.4 执行多个档案的编辑  
2.5 执行 sed 输出控制  
2.1.执行命令列上的编辑指令  
  当编辑指令(参照[section 2.2])在命令列上执行时 , 其前必须加上选项 -e 。
其命令格式如下 :  
 
    sed -e '编辑指令1' -e '编辑指令2' ... 文件档   
 
其中 , 所有编辑指令都紧接在选项 -e 之後 , 并置於两个 " ' " 特殊字元间。
另外 , 命令上编辑指令的执行是由 
左而右。 
 
  一般编辑指令不多时 , 使用者通常直接在命令上执行它们。例如 , 删除 yel.
dat 内 1 至 10 行资料 , 并将其 
  馀文字中的 "yellow" 字串改成 "black" 字串。此时 , 可将编辑指令直接在命
令上执行 , 其命令如下 :  
 
    sed -e '1,10d' -e 's/yellow/black/g' yel.dat   
 
在命令中 , 编辑指令 '1,10d'(解[5])执行删除 1 至 10 行资料 ; 编辑指令 
's/yellow/black/g'(解[6]) ,  
"yellow" 字串替换(substuite)成 "black" 字串。  
2.2 sed 的编辑指令  
  sed 编辑指令的格式如下 :  
             [address1[,address2]]function[argument] 
 
其中 , 位址参数 address1 、address2 为行数或 regular expression 字串 , 
表示所执行编辑的资料行 ; 函数参 
数 function[argument] 为 sed 的内定函数 , 表示执行的编辑动作。  
下面两小节 , 将仔细介绍位址参数的表示法与有哪些函数参数供选择。  
 
2.2.1 位址(address)参数的表示法 
  实际上 , 位址参数表示法只是将要编辑的资料行 , 用它们的行数或其中的字串
来代替表示它们。下面举几个例子 
  说明(指令都以函数参数 d(参照[section4.2]) 为例) :  
删除档内第 10 行资料 , 则指令为 10d。  
删除含有 "man" 字串的资料行时 , 则指令为 /man/d。  
删除档内第 10 行到第 200 行资料, 则指令为 10,200d。  
 
删除档内第 10 行到含 "man" 字串的资料行 , 则指令为 10,/man/d。  
  接下来 , 以位址参数的内容与其个数两点 , 完整说明指令中位址参数的表示法
(同样也以函数参数 d 为例)。  
位址参数的内容:  
位址为十进位数字 : 此数字表示行数。当指令执行时 , 将对符合此行数的资料执
行函数参数指示的编辑动作。例如 ,  
删除资料档中的第 15 行资料 , 则指令为 15d(参照[section4.2])。其馀类推 ,
如删除资料档中的第 m 行资料 , 则 
指令为 md 。  
 
位址为 regular expression(参照[附录 A]): 
当资料行中有符合 regular expression 所表示的字串时 , 则执行函数参数指示
的编辑动作。另外 , 在  
regular expression 前後必须加上 "/"。例如指令为 /t.*t/d , 表示删除所有含
两 "t" 字母的资料行。其中 , "."  
表示任意字元; "*" 表示其前字元可重任意次 , 它们结合 ".*" 表示两 "t" 字母
间的任意字串。  
 
位址参数的个数 : 在指令中 , 当没有位址参数时 , 表示全部资料行执行函数参
数所指示的编辑动作; 当只有一位址 
参数时 , 表示只有符合位址的资料行才编辑 ; 当有两个位址参数 , 如 
address1,address2 时 , 表示对资料区执行 
编辑 , address1 代表起始资料行 , address2 代表结束资料行。对於上述内容 ,
 以下面例子做具说明。  
 
例如指令为  
 
d  
 
其表示删除档内所有资料行。  
例如指令为  
 
5d  
 
其表示删除档内第五行资料。  
例如指令为  
 
1,/apple/d 
 
其表示删除资料区 , 由档内第一行至内有 "apple" 字串的资料行。  
例如指令为  
 
/apple/,/orange/d  
 
其表示删除资料区 , 由档内含有 "apple" 字串至含有 "orange" 字串的资料行 
 
2.2.2 有那些函数(function)参数  
  下页表中介绍所有 sed 的函数参数(参照[chapter 4])的功能。 
函数参数 功能  
∶ label  建立 script file 内指令互相参考的位置。   
#  建立解   
{ }  集合有相同位址参数的指令。   
!  不执行函数参数。   
=  印出资料行数( line number )。   
a  添加使用者输入的资料。   
b label  将执行的指令跳至由 : 建立的参考位置。   
c  以使用者输入的资料取代资料。  
 
d  删除资料。   
D  删除 pattern space 内第一个 newline 字母 前的资料。   
g  拷贝资料从 hold space。   
G  添加资料从 hold space 至 pattern space 。   
h  拷贝资料从 pattern space 至 hold space 。   
H  添加资料从 pattern space 至 hold space 。   
l  印出 l 资料中的 nonprinting character 用 ASCII 码。   
i  插入添加使用者输入的资料行。   
n  读入下一笔资料。   
N  添加下一笔资料到 pattern space。   
p  印出资料。   
P  印出 pattern space 内第一个 newline 字母 前的资料。   
q  跳出 sed 编辑。   
r  读入它档内容。   
s  替换字串。   
t label  先执行一替换的编辑指令 , 如果替换成牛p>则将编辑指令跳至 : label
 处执行。   
w  写资料到它档内。   
x  交换 hold space 与 pattern space 内容。   
y  转换(transform)字元。   
虽然 , sed 只有上表所述几个拥有基本编辑功能的函数 , 但由指令中位址参数和
指令与指令间的配合 , 也能使  
sed 完成大部份的编辑任务。  
2.3 执行档案内的编辑指令  
  当执行的指令太多 , 在命令列上撰写起来十分混乱 , 此时 , 可将这些指令整
理储存在档案 
  (譬如档名为 script_file )内 , 用选项 -f script_file , 则让 sed 执行 
script_file 内的编辑指令。其命 
  令的格示如下 :  
     sed -f script_file 文件档   
 
其中 , 执行 script_file 内编辑指令的顺序是由上而下。例如上一节的例子 , 
其可改成如下命令:  
     sed -f ysb.scr yel.dat   
 
其中 , ysb.scr 档的内容如下 :  
1,10d 
s/yellow/black/g 
 
  另外 , 在命令列上可混合使用选项 -e 与 -f , sed 执行指令顺序依然是由命
令列的左到右, 如执行至 -f 後 
  档案内的指令 , 则由上而下执行。  
 
 
2.4 执行多个文件档的编辑  
  在 sed 命令列上 , 一次可执行编辑多个文件档 , 它们跟在编辑指令之後。例
如 , 替换 
   white.dat、red.dat、black.dat 档内的 "yellow" 字串成 "blue" , 其命令
如下:  
      sed -e 's/yellow/blue/g' white.dat red.dat black.dat  
 
上述命令执行时 , sed 依 white.dat、red.dat、black.dat 顺序 , 执行编辑指
令 s/yellow/blue/(请参照[section 4.1] ,  
进行字串的替换。 
 
2.5.执行输出的控制  
  在命令列上的选项 -n (解[7]) 表示输出由编辑指令控制。由前章内容得知 , 
sed 会 "自动的" 将资料由 
   pattern space 输送到标准输出档。但藉着选项 -n , 可将 sed 这 "自动的
" 的动作改成 "被动的" 由它所执行的 
   编辑指令(解[8])来决定结果是否输出。  
  由上述可知 , 选项 -n 必须与编辑指令一起配合 , 否则无法获得结果。例如 ,
 印出 white.dat 档内含有 "white"  
  字串的资料行 , 其命令如下:  
 
      sed -n -e '/white/p' white.dat    
 
上面命令中 , 选项 -n 与编辑指令 /white/p (参照[section4.6]) 一起配合控制
输出。其中 , 选项 -n 将输出控制权 
移给编辑指令;/white/p 将资料行中含有 "white" 字串印出萤幕。   
 

=====================================================

1.sed -n '2'p filename
打印文件的第二行。

2.sed -n '1,3'p filename
打印文件的1到3行

3. sed -n '/Neave/'p filename
打印匹配Neave的行(模糊匹配)

4. sed -n '4,/The/'p filename
在第4行查询模式The

5. sed -n '1,$'p filename
打印整个文件,$表示最后一行。

6. sed -n '/.*ing/'p filename
匹配任意字母,并以ing结尾的单词(点号不能少)

7 sed -n / -e '/music/'= filename
打印匹配行的行号,-e 会打印文件的内容,同时在匹配行的前面标志行号。-n只打印出实际的行号。

8.sed -n -e '/music/'p -e '/music/'= filename
打印匹配的行和行号,行号在内容的下面

9.sed '/company/' a "Then suddenly it happend" filename
选择含有company的行,将后面的内容"Then suddenly it happend"加入下一行。注意:它并不改变文件,所有

操作在缓冲区,如果要保存输出,重定向到一个文件。

10. sed '/company/' i "Then suddenly it happend" filename
同9,只是在匹配的行前插入

11.sed '/company/' c "Then suddenly it happend" filename
用"Then suddenly it happend"替换匹配company的行的内容。

12.sed '1'd ( '1,3'd '$'d '/Neave/'d) filename
删除第一行(1到3行,最后一行,匹配Neave的行)

13.[ address [,address]] s/ pattern-to-find /replacement-pattern/[g p w n]
s选项通知s e d这是一个替换操作,并查询pattern-to-find,成功后用replacement-pattern替换它。
替换选项如下:
g 缺省情况下只替换第一次出现模式,使用g选项替换全局所有出现模式。
p 缺省s e d将所有被替换行写入标准输出,加p选项将使- n选项无效。- n选项不打印输出结果。
w 文件名使用此选项将输出定向到一个文件。(注意只将匹配替换的行写入文件,而不是整个内容)

14.sed s'/nurse/"hello "&/' filename
将'hello '增加到'nurse' 的前面。

15. sed '/company/r append.txt' filename
在匹配company的行的下一行开始加入文件append.txt的内容。

16. sed '/company/'q filename
首次匹配company后就退出sed程序

==============================


sed 's/abc/123/g' myfile

sed -n 's/^west/north/p' myfile
打印替换了west开头用north替换的行

sed -n '/aa/,/bb/p' myfile
打印在包含以aa开头到以bb结束的行

sed '1,4s/aa/bb/g' myfile

sed '4,/aa/s/11/22/g' myfile
在第4行后到包含aa结束的行中,替换11为22

sed 'aa/,/bb/s/11/22/g' myfile
在包含以aa开头到以bb结束的行中,替换11为22

sed '1,5s/$/cc/' myfile
每行的末尾以cc来替换

--e-----------------------
sed -e '1,3d' -e 's/aa/bb/' myfile
对myfile同时执行d 与s 操作

--w-----------------------
sed -n '/north/w newfile' myfile
把myfile中包含north的行写入newfile中

--a-----------------------
sed '/^north /a \
----->add string------------------' myfile
往myfiel追加行

--i-----------------------
sed '/aa/i\
new line1--------------
------------new line2--------------' myfile

在包含/aa的行下插入行

--n--------------------
sed /aa/{n;s/11/22/;} myfile
找到包含aa的行后,对下一行执行s操作

--y--------------------

sed 1,3y/abcdefg/ABCDEFG' myfile
在1,3行中把abcdefg变形为ABCDEFG

--q---------------------
sed '5q' myfile
推出命令。执行到5行后退出

--h 与 g,x--------------
sed -e '/aa/h' -e '$g' myfile
把包含aa的行放如缓冲区,在最后一行中增加(也就是把包含有aa的行追加到最后一行中)


sed -e '/aa/{h;d; }' -e '/bb/{g;}' myfile
把包含aa的行放入缓冲区,删除包含aa的行;找到bb的行后,把aa的行在后面追加

sed -e '/aa/h' -e '$g' myfile

sed -e '/aa/h' -e '/bb/x' myfile
把包含aa的行放入缓冲区,当出现/bb的行时,则把bb的内容换为缓冲区的内容

阅读(1336) | 评论(0) | 转发(0) |
0

上一篇:awk

下一篇:linux学习笔记之启动过程

给主人留下些什么吧!~~