Применить список шаблонов регулярных выражений над строкой и найти найденные совпадения - PullRequest
0 голосов
/ 18 декабря 2018

У меня есть несколько регулярных выражений, и мне нужно сопоставить их все с одной строкой, и мне нужно выяснить, соответствует ли регулярное выражение ведьмы.

import re
re_list=['a',' b','c','\s+d']
str="a uuu d e 1 2 3"
re_pattern = re.compile( '|'.join( re_list) )

m=re.search(re_pattern, str)

Но это не работает.Я хочу получить словарь, сопоставляющий шаблон с подстрокой.

{"a" : "a",
"\s+d": " d"}

Как я могу это сделать?

1 Ответ

0 голосов
/ 18 декабря 2018

Сначала скомпилируйте ваши шаблоны:

import re
ps = [re.compile(p) for p in re_list]

Теперь вы можете перебирать их:

d = {}
for p in ps:
    # `string` is your string. Please don't use `str` to name variables.
    m = p.search(string)
    if m:  
        d[p.pattern] = m.group()

print(d)
{'a': 'a', '\\s+d': ' d'}

Вы могли бы сделать это с пониманием списка

dict((p.pattern, p.search(s).group()) for p in ps if p.search(s))

Но вам придется искать дважды, что расточительно.Вы можете избежать этого, вместо этого запустив цикл над шаблонами, как я показал выше.

...