免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
123
最近访问板块 发新帖
楼主: sardinescn
打印 上一主题 下一主题

grep 正则表达式{n,m}的问题 [复制链接]

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
21 [报告]
发表于 2009-08-03 18:06 |只看该作者

回复 #20 sardinescn 的帖子

匹配的应该是前面的两个b,而不是后面的.

论坛徽章:
0
22 [报告]
发表于 2009-08-03 18:09 |只看该作者
又仔细想了一下,我上面的理解还是说不同,如果说匹配的是最后两个b话,那么前面的b是怎么混进去了的呢?

论坛徽章:
0
23 [报告]
发表于 2009-08-03 18:11 |只看该作者
呵呵,如果匹配的是前面的b,那我又迷糊了。 问题出在哪里呢?

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
24 [报告]
发表于 2009-08-03 18:13 |只看该作者

回复 #23 sardinescn 的帖子

啥问题?说清楚。

论坛徽章:
0
25 [报告]
发表于 2009-08-03 18:16 |只看该作者
我的例子:
abbccdd
abbbccdd
grep -E 'ab{1,2}’ 的结果是两行都出来。
而你的例子
aab
aaab
grep -E '^a{1,2}' 只匹配出第1行。

区别在哪里? 为什么?

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015年亚洲杯之朝鲜
日期:2015-03-13 22:47:33IT运维版块每日发帖之星
日期:2016-01-09 06:20:00IT运维版块每周发帖之星
日期:2016-03-07 16:27:44
26 [报告]
发表于 2009-08-03 18:18 |只看该作者

回复 #25 sardinescn 的帖子

我的也是出来两行啊
  1. $ echo "aab\naaab"|grep -E '^a{1,2}'
  2. aab
  3. aaab
复制代码


出来一行是因为后面那个b.

论坛徽章:
0
27 [报告]
发表于 2009-08-03 18:24 |只看该作者
哦,终于想明白了。  多谢。

论坛徽章:
0
28 [报告]
发表于 2009-08-07 17:02 |只看该作者
{n,m}还是蛮好理解的啊。

论坛徽章:
0
29 [报告]
发表于 2009-08-09 10:12 |只看该作者
哥们,看来你理解有误了。所有的模式只针对字符串来匹配的,不是针对行来讲的。
b{2}只是匹配bb这两个字符,不管文件里有几行,只要有bb的都会匹配出来。
b{2,}匹配2个或者2个以上的连写

[ 本帖最后由 angeljyt 于 2009-8-9 10:15 编辑 ]

论坛徽章:
0
30 [报告]
发表于 2009-08-27 18:03 |只看该作者
明显没有看SHELL十三问,匹配是要结合“分界”来看的。
如果没有分界,/aa/即匹配aa还匹配aaa, aaaa, aaaaaaa
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP