python正则--group

python正则--group,第1张

group作用:
python正则中,用group函数来定位括号表达式匹配到的结果中特定的字段,你可以理解为索引,有n个括号表达式group里面的索引最大值就是n,group(k)就代表第k个括号表达式匹配到的结果,group()/group(1),打印出所有的匹配结果

.* 代表匹配除换行符之外的所有字符
.*? 后面多个问号,代表非贪婪模式,也就是说只匹配符合条件的最少字符

如果不使用括号表达式,那么只能使用group()/group(1),打印出所有的匹配结果,而不能使用group(k)

import re

line = "some cats are smarter than dogs are true"
mat1 = re.match(r".* are", line)
mat2 = re.match(r".*? are", line)

print(mat1)
print(mat2)
print(mat1.group(0))
# 
# 
# some cats are smarter than dogs are

加上索引则会报错:

print(mat1.group(1))
# IndexError: no such group

使用括号表达式,根据索引获取匹配结果:

import re

line = "some cats are smarter than dogs are true"
mat1 = re.match(r"(.*) are", line)
mat2 = re.match(r"(.*?) are .* dogs (.*)", line)

print(mat1.group(1))
print(mat2)
print(mat2.group(1))
print(mat2.group(2))


# some cats are smarter than dogs
# 
# some cats
# are true

group()一次可以跟多个索引,会生成一个元组

print(type(mat2.group(2, 1)))
# ('are true', 'some cats')
# 

groups()则是把所有的group()生成一个元组

print(mat2.groups())
print(type(mat2.groups()))

# ('some cats', 'are true')
# 

如果没有括号表达式,直接使用groups()则会得到一个空的元组

import re

line = "some cats are smarter than dogs are true"
mat1 = re.match(r".* are", line)
print(mat1.groups())
# ()

欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/langs/922654.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-05-16
下一篇2022-05-16

发表评论

登录后才能评论

评论列表(0条)

    保存