パターン内に複数のキャプチャグループを持つre.finditerの作業パターンを構築するのに問題があります。私はデータを検索したい次の文字列を持っています。Python 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);
"""
私は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
「位置72の不均衡な括弧」はヒントを与えますか? –
@JonClementsはヒントのためにありがとう。問題が更新されました。依然としてゼロの結果を印刷します。 – jonas778
あなたはスペースを食べていません... :) –