我有一个包含以下内容的文本块:
race={ heat1={ names={ ALEX DAN PETER } } heat2={ names={ RYAN DYLAN } } }
如何构建一个正则表达式以将所有heat1名称放入组1中,并将所有heat2名称放入组2中?我无法找到已经被问过的一对一问题,而我能得到的最接近的问题是:
(?:names={)( [A-z]+ )
返回同一组中的ALEX和RYAN。
答案 0 :(得分:2)
使用re.findall()
功能:
import re
s = 'race={ heat1={ names={ ALEX DAN PETER } } heat2={ names={ RYAN DYLAN } } }'
result = re.findall(r'heat[12]=\{ names=\{ ([^}]+[^}\s])', s)
print(result)
输出:
['ALEX DAN PETER', 'RYAN DYLAN']