У меня есть несколько регулярных выражений, и мне нужно сопоставить все из них с одной строкой, и мне нужно узнать, что регулярное выражение ведьмы сопоставлено.
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"}
Как я могу это сделать?
Сначала скомпилируйте свои паттерны:
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))
Но вам придется искать дважды, что расточительно. Вы можете избежать этого, запустив вместо этого цикл по шаблонам, как я показал выше.