re.findall("(100|[0-9][0-9]|[0-9])%", "89%")
这只返回结果[89]
,我需要返回整个89%。有什么想法可以吗?
答案 0 :(得分:10)
>>> re.findall("(?:100|[0-9][0-9]|[0-9])%", "89%")
['89%']
当有捕获组findall
时,仅返回捕获的部分。使用?:
可防止括号成为捕获组。
答案 1 :(得分:6)
琐碎的解决方案:
>>> re.findall("(100%|[0-9][0-9]%|[0-9]%)","89%")
['89%']
更美丽的解决方案:
>>> re.findall("(100%|[0-9]{1,2}%)","89%")
['89%']
最漂亮的解决方案:
>>> re.findall("(?:100|[0-9]{1,2})%","89%")
['89%']
答案 2 :(得分:2)
使用外部组,内部组为非捕获组:
>>> re.findall("((?:100|[0-9][0-9]|[0-9])%)","89%")
['89%']