Chinaunix首页 | 论坛 | 博客
  • 博客访问: 369273
  • 博文数量: 159
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 182
  • 用 户 组: 普通用户
  • 注册时间: 2013-11-02 10:42
文章分类

全部博文(159)

文章存档

2015年(18)

2014年(132)

2013年(9)

分类: LINUX

2014-05-30 16:13:29

原文地址:sed 正则表达式 作者:ztguang



如果testfile的内容是

Hello World
Welcome to the world of regexp!

现在要去掉所有的HTML标签,使输出结果为

Hello World
Welcome to the world of regexp!

怎么做呢?如果用下面的命令

$ sed 's/<.*>//g' testfile


结果是两个空行,把所有字符都过滤掉了。这是因为,正则表达式中的数量限定符会匹配尽可能长的字符串,这称为贪心的(Greedy)[]。比如sed在处理第一行时,<.*>匹配的并不是或这样的标签,而是

Hello World

这样一整行,因为这一行开头是<,中间是若干个任意字符,末尾是>。那么这条命令怎么改才对呢?留给读者思考。


+++++++++++++++++++++++++++++
学生:卢峰

sed  's/<[a-z|/]*>//g'  testfile

+++++++++++++++++++++++++++++

sed  's/<[^<>]*>//g'  testfile
阅读(1003) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~