Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2980771
  • 博文数量: 272
  • 博客积分: 5544
  • 博客等级: 大校
  • 技术积分: 5496
  • 用 户 组: 普通用户
  • 注册时间: 2011-03-08 00:48
个人简介

  每个人都要有一个骨灰级的爱好,不为金钱,而纯粹是为了在这个领域享受追寻真理的快乐。

文章分类

全部博文(272)

文章存档

2015年(2)

2014年(5)

2013年(25)

2012年(58)

2011年(182)

分类: LINUX

2011-11-08 18:40:26

文本:
aa
88
bb
88
88
cc
88
88



替换第一个88为--:
  1. sed '0,/88/s//--/' file

  2. sed ':a;N;$!ba;s/88/--/' file
[解析]
这有两种方法,第一个是只匹配到第一个88为止,然后替换那个88为--。
第二个句子是通过循环把文本全部读进pattern space 然后只替换第一个。



替换第N[3]个88为--:
  1. #替换第三个
  2. sed '/88/{x;s/^/./;/^\.\{3\}$/{x;s/.*/--/;x};x;}' file

  3. sed ':a;N;$!ba;s/88/--/3' file
[解析]
第一个命令叫打点记数法,因为sed没有 var++ 之类的操作来记数。
第二个命令和上面第一个其实是一样的原理,全部读入文本后统一替换第3个匹配的内容。




替换最后一个匹配的88为--:
  1. sed ':a;/\n88/!{$s/88/--/;N;ba};P;D' file

  2. sed ':a;N;$!ba;s/\(.*\)88/\1--/' file
[解析]
第一个命令,没匹配到 /\n88/ 的内容就读取下一行,然后 ba 跳转去开始处,如果读取到88的行呢,就执行后面的 P;D 组合,D也有循环功能,一直把匹配 \n88 内容的第一行打印,删除,直到不匹配/\n88/(因为换行符已经被打印出去了,所以不再会匹配到 \n88),这时候才继续往下读,如果又读到88的行,那么又执行P;D循环,同上操作。一直到匹配到最后一个88的行,继续读取到末行时执行替换,N 因为没有下一行可读,所以会自动中止命令,因为没有 -n 参数会打印 pattern space 里的内容到屏幕,所以就不会再执行后面的 ba 避免了死循环,这样的用法只存在于 GNU sed ,大家注意。所以这整个流程只会替换最后一个88。
第二个命令其实和上面的都一样,也是全部读进 pattern space 里,最后利用正则的贪婪替换掉最后一个88。

阅读(12796) | 评论(1) | 转发(0) |
给主人留下些什么吧!~~

天高皇帝远那2011-11-10 03:15:02

学习了~