关于python的re正则模块

>>>m=re.match("([abc])+","abc")>>>m.groups()这个输出的是('c',)这个有点无法理解啊。为什么第一捕获组会是c,[abc]不是... >>> m = re.match("([abc])+", "abc")
>>> m.groups()
这个输出的是
('c',)
这个有点无法理解啊。
为什么第一捕获组会是c,[abc]不是匹配a or b or c么 。为啥独独会是c
展开
 我来答
bdwisyou7d
2013-10-17 · TA获得超过1.3万个赞
知道大有可为答主
回答量:3775
采纳率:81%
帮助的人:1084万
展开全部
你的括号位置错误了一点儿。我自己也是试了几次才明白。

这样写就对了。

m = re.match("([abc]+)", "abc")

你的括号只包括了一个字符,而不是所有的字符。所以结果是c,或者是a都有可能。当然c可能性更大些。只有将+号包括进去后才会得到abc。

至于为什么是C,因为你括号取的是一组字符中的一个,按正则的规则,它会顺序取。当然寄存器里保存的是最后一个字符,这样效率最高。
wanghan519
2013-10-17 · TA获得超过7820个赞
知道小有建树答主
回答量:1285
采纳率:60%
帮助的人:563万
展开全部
楼上已经发了,我删掉我的回答了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式