Chinaunix首页 | 论坛 | 博客
  • 博客访问: 171322
  • 博文数量: 25
  • 博客积分: 3015
  • 博客等级: 中校
  • 技术积分: 545
  • 用 户 组: 普通用户
  • 注册时间: 2007-08-15 17:00
文章分类

全部博文(25)

文章存档

2010年(1)

2009年(9)

2008年(15)

我的朋友

分类:

2008-03-10 15:39:32

sed "s/&&/|/g" test >boss15_yx_cr_grouprela_SZ
 
 
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''$''/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命令,是因为我遇到了这个一个问题。 
网上有很多教程,他们发表了很多程序代码,但是作者为了解释方便,都对程序作了行号编码,就像下面这样: 

代码::
 
1:#!/bin/bash 
2:#rename file extesions 
3:# 
4:#     rfe old_extensions new_extension
 

假设这个文件名是tmp,那么我们可以使用下面的命令来去掉这个行号和冒号(:) 

代码::
 

sed -e  s'/^[0-9]\{1,\}://g' tmp
 

不过上面的命令的命令有一个缺点,那就是如果这个行号不是数字开头,而是有空格的话,那就需要修改匹配规则,规则应该修改为匹配第一个非空白字符是数字开始,后面接一个冒号的配对。命令如下: 

代码::
 
sed -e  s'/^[^0-9a-zA-Z]*[0-9]\{1,\}://g' tmp
阅读(1150) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~