Shady Atef Shady Atef - 1 year ago 85
Python Question

Python - Regex findall repeated pattern followed by variable length of chars

I have the following pattern:

1MHG161 xxxxxxxxxxxxx 1MHG161 xxx

is variable length of chars & spaces.

I am trying to capture each one and have the following expected output:

[ '1MHG161 xxxxxxxxxxxxx ' , '1MHG161 xxx' ]

I have tried a lot of combination this is the last one

messages_strings = re.findall("(1MHG161.+?)(?=1MHG161)",content)

This finds all except the last one.

Edit 1:

I have taken @anubhava answer, a little bit further to solve the same problem but with dynamic delimiters by using
instead of

This may help people working with EDI parsers.

Answer Source

You can use:

>>> re.findall(r"(1MHG161.+?)(?=1MHG161|$)", content)
['1MHG161  xxxxxxxxxxxxx  ', '1MHG161 xxx']

Lookahead (?=1MHG161|$) will match 1MHG161 or end of line anchor $ after your match.

Recommended from our users: Dynamic Network Monitoring from WhatsUp Gold from IPSwitch. Free Download