python 正则表达式

发布网友 发布时间:2022-04-23 13:09

我来回答

2个回答

热心网友 时间:2022-04-18 05:00

这个问题的确比较纠结首先明确一点
m.groups()==m.group(1)+m.group(2)+...+m.group(n)
要确定m.group(n)中的n到底是多少???
1.在你的匹配式中出现了几次匹配成功的括号,n就是几
给你举个例子m = re.match("([abc])+([abc])+", "abc"):
它出现了2次括号,且这两次括号都能匹配,所以n=2。你可以print m.group(2)不会报错,而 m = re.match("([abc])+", "abc"),print m.group(2)则会报错
2.其次python的匹配引擎是从后面开始的
在给你举个对比的例子:
例子1:m = re.match("([abc])+([abc])+([abc])+", "abc"):
如果你理解第一点,n=3,然后你可以print 一下 你会发现:
m.group(3)=‘c’ ,m.group(2)='b',m.group(1)='a'

例子2:m = re.match("([abc])+([abc])+", "abc"):
m.group(1)=b,m.group(2)='c'
( python中说明了n在0-99间都是可以的,如果超出的话IndexErrorexception跳出)

如果你能看明白那么应该groups的相应东西你理解的差不多了,接下来看你第二问
?表示匹配前面的表达式0个或一次,例子:go?匹配go为0或者1次
:呵呵 就是冒号的意思,所以你懂的,没匹配到

写那么多,如果不明白,可以再问我哈 万请采纳

热心网友 时间:2022-04-18 06:18

大概知道你想干嘛,写成
re,match("([abc]+)", "abc")
就行了。
括号是捕获组的意思,在匹配后可以通过索引获取匹配的内容,而(?: xxx)是非捕获组,即该括号内的东西即使匹配也不会被捕获

声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com