免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2016 | 回复: 3
打印 上一主题 下一主题

请教re匹配的小问题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-11-08 11:18 |只看该作者 |倒序浏览
本帖最后由 werm520 于 2011-11-08 11:22 编辑
  1. >>> import re
  2. >>> print re.match("([abc])+", "abc")
  3. <_sre.SRE_Match object at 0x7f6deae08120>
  4. >>> print re.match("([abc])+", "abc").group()
  5. abc
  6. >>> print re.match("([abc])+", "abc").groups()    //疑问:这为什么会输出'c',应该输出'a'啊
  7. ('c',)
  8. >>> print re.match("([abc])+", "abc").group(1)    //个人认为这个与上面的匹配应该是相同的
  9. c
  10. >>> print re.match("[abc]", "abc").group()          //我这单独将组剔出,进行匹配输出的是'a'
  11. a
复制代码
难道是我组的概念理解误?

小组是从左向右计数的,从1开始。组可以被嵌套。计数的数值可以能过从左到右计算打开的括号数来确定。

那么我理解第三次输出应该与第二次相同才对啊?{:3_204:}这是怎么回事

P.S:而且用match也应该匹配'abc'的开头,也应该为'a'吧。 请问这是什么原因?

论坛徽章:
0
2 [报告]
发表于 2011-11-08 15:52 |只看该作者
python的文档是这么说的。
If a group matches multiple times, only the last match is accessible:

>>> m = re.match(r"(..)+", "a1b2c3")  # Matches 3 times.
>>> m.group(1)                        # Returns only the last match.
'c3'

论坛徽章:
0
3 [报告]
发表于 2011-11-08 16:03 |只看该作者
回复 2# jsjzhh


    re~,看文档是个好习惯

论坛徽章:
0
4 [报告]
发表于 2011-11-08 16:12 |只看该作者
回复 2# jsjzhh


终于等到了,呵呵,谢谢帮忙~   
看的中文资料,2本书都没有书这个,也去查了The Python Standard Library,不过只查了match和组的…… {:3_203:}
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP