我们知道re.findall()可以匹配所有不重叠的匹配成功的部分,那如何进行可重叠的匹配呢?求大神不吝赐教。
举一个例子
假设text = "acbca"
,pattern = "(a.*b)|(b.*a)"
使用re.findall(pattern, text)
结果是这样的: [("acb", "")]
"bca"
这一个片段并不会被找到。问题就是,如何让"acb"
和"bca"
两个片段都能被匹配上呢?
我们知道re.findall()可以匹配所有不重叠的匹配成功的部分,那如何进行可重叠的匹配呢?求大神不吝赐教。
举一个例子
假设text = "acbca"
,pattern = "(a.*b)|(b.*a)"
使用re.findall(pattern, text)
结果是这样的: [("acb", "")]
"bca"
这一个片段并不会被找到。问题就是,如何让"acb"
和"bca"
两个片段都能被匹配上呢?
2 回答5.2k 阅读✓ 已解决
2 回答1.1k 阅读✓ 已解决
4 回答1.4k 阅读✓ 已解决
3 回答1.3k 阅读✓ 已解决
3 回答1.3k 阅读✓ 已解决
2 回答893 阅读✓ 已解决
1 回答1.8k 阅读✓ 已解决
key = "gost.default.api.access.user.kicktype.limitusers.count@"
p1 = ".((api)\.access)."
pattern1 = re.compile(p1)
matcher1 = re.search(pattern1,key)
matcher1.group(0)
matcher1.group(1)
matcher1.group(2)
使用()保存捕获组