re.findall("(100|[0-9][0-9]|[0-9])%", "89%")
这仅返回结果[89]
,我需要返回全部 89%。请问有什么办法吗?
>>> re.findall("(?:100|[0-9][0-9]|[0-9])%", "89%")
['89%']
当有捕获组时,findall
仅返回捕获的部分。用于?:
防止括号成为捕获组。
简单的解决方案:
>>> 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%']
使用外部组,内部组为非捕获组:
>>> re.findall("((?:100|[0-9][0-9]|[0-9])%)","89%")
['89%']