2017-05-09 3 views
0

パターン内に複数のキャプチャグループを持つ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 
+0

「位置72の不均衡な括弧」はヒントを与えますか? –

+0

@JonClementsはヒントのためにありがとう。問題が更新されました。依然としてゼロの結果を印刷します。 – jonas778

+0

あなたはスペースを食べていません... :) –

答えて

1

あなたは例えば、口座に数字の後にスペースを取る必要があります。

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 
260 
+0

あなたは素晴らしいです!私は長い間この問題を抱えていたので、あなたはそれをちょうど解決しました!どうもありがとう! – jonas778

関連する問題