在一个模式中使用多个捕获组构建一个工作的、正确的re.finditer模式是有问题的。我有以下字符串,我想搜索数据。
search_string="""
option.Map['2015'] = new CG.New.Option('text1', '2015', 100, 200);
option.Map['2016'] = new CG.New.Option('text2', '2016', 150, 210);
option.Map['2017'] = new CG.New.Option('text3', '2017', 160, 260);
"""我想使用Python提取文本、年份和数字。我的模式如下所示:
pattern=r"option.Map\[\'(.*)\'] = new CG\.New\.Option\(\'(.*)\',\'(.*)\',(.*),(.*)\);"我的代码如下所示:
for finding in re.finditer(pattern,search_string):
    print(finding.group(1))
    print(finding.group(2))
    print(finding.group(3))
    print(finding.group(4))
    print(finding.group(5))我知道我的模式已经过时了,但我不知道为什么。
我希望/希望实现的输出如下所示:
2015
text1
2015
100
200
2016
text2
2016
150
210
2017
text3
2017
160
260发布于 2017-05-09 21:52:38
你需要考虑数字后的空格(如:
import re
search_string = """
option.Map['2015'] = new CG.New.Option('text1', '2015', 100, 200);
option.Map['2016'] = new CG.New.Option('text2', '2016', 150, 210);
option.Map['2017'] = new CG.New.Option('text3', '2017', 160, 260);
"""
pattern = r"option.Map\['(.*?)'\] = new CG.New.Option\('(.*?)', '(.*?)', (\d+), (\d+)\);"然后:
for match in re.finditer(pattern, search_string):
    print(*match.groups(), sep='\n')给你:
2015
text1
2015
100
200
2016
text2
2016
150
210
2017
text3
2017
160
260https://stackoverflow.com/questions/43879615
复制相似问题