Chinaunix首页 | 论坛 | 博客
  • 博客访问: 47497
  • 博文数量: 19
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 28
  • 用 户 组: 普通用户
  • 注册时间: 2014-12-16 14:42
文章分类
文章存档

2015年(16)

2014年(3)

我的朋友

分类:

2015-03-12 17:14:21

原文地址:扩展正则表达式 作者:zhengsenlin888

去除空行与#开头的行
grep -v '^$' a.txt | grep -v '^#' 这样需要管道来搜索两次
下面使用扩展正则表达式
egrep -v '^$|^#' a.txt

+ 重复一个或一个以上的字符
搜索god good goood等字符串,o+代表一个以上的o
egrep -n 'go+d' a.txt

? 0个或1个字符
搜索gd 或者 god字符串的行
egrep -n 'go?d' a.txt

| 用或(or)的方式找出数个字符串
egrep -n 'gd|good' a.txt
找出含有gd或者god的字符串的行

() 找出含有glad或good或gaad或glod这两个字符串的行
egrep -n 'g(la|oo|aa|lo)' a.txt

!在正则表达式中不是特殊字符
查找出含有(!)与(>)的行
grep -n '[!>]' a.txt


RE 字符意义与范例
+重复『一个或一个以上』的前一个 RE 字符
范例:egrep -n 'go+d' regular_express.txt
搜寻 (god) (good) (goood)... 等等的字符串。 那个 o+ 代表『一个以上的 o 』所以,上面的执行成果会将第 1, 9, 13 行列出来。
?『零个或一个』的前一个 RE 字符
范例:egrep -n 'go?d' regular_express.txt
搜寻 (gd) (god) 这两个字符串。 那个 o? 代表『空的或 1 个 o 』所以,上面的执行成果会将第 13, 14 行列出来。
有没有发现到,这两个案例( 'go+d' 与 'go?d' )的结果集合与 'go*d' 相同? 想想看,这是为什么喔! ^_^
|用或( or )的方式找出数个字符串
范例:egrep -n 'gd|good' regular_express.txt
搜寻 gd  good 这两个字符串,注意,是『或』! 所以,第 1,9,14 这三行都可以被打印出来喔!那如果还想要找出 dog 呢?就这样啊:
egrep -n 'gd|good|dog' regular_express.txt
( )找出『群组』字符串
范例:egrep -n 'g(la|oo)d' regular_express.txt
搜寻 (glad) 或 (good) 这两个字符串,因为 g 与 d 是重复的,所以, 我就可以将 la 与 oo 列于 ( ) 当中,并以 | 来分隔开来,就可以啦!
此外,这个功能还可以用来作为『多个重复群组』的判别喔!举例来说:
echo 'AxyzxyzxyzxyzC' | egrep 'A(xyz)+C'
上面的例子当中,意思是说,我要找开头是 A 结尾是 C ,中间有一个以上的 "xyz" 字符串的意思~

以上这些就是延伸型的正则表达式的特殊字符。另外,要特别强调的是,那个 ! 在正则表达式当中并不是特殊字符, 所以,如果您想要查出来档案中含有 ! 与 > 的字行时,可以这样:
    grep -n '[!>]' regular_express.txt
这样可以了解了吗?!常常看到有陷阱的题目写:『反向选择这样对否? '[!a-z]'?』, 呵呵!是错的呦~要 '[^a-z] 才是对的!


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