re.match() 関数や re.search() 関数では複数のマッチが取れない match() 関数や search() 関数ではパターンがマッチした場合、最初のマッチオブジェクトが返ります。 例えば、次のように「複数文字列の中で Hello に続く文字」を取得したいとします。そこで、次のようなコードを書いたとします。 import re s = """abc Hello world! Hello Python! xyz""" match = re.search(r'^Hello (.*)$', s, re.MULTILINE) if match is None: print('Not match') else: print(match.groups()) この実行結果は次のようになります。 ('world!',) world! は取得できていますが、その次の行の Python! は