[英]Apply a list of regex patterns over a string and return matches found
我有多個正則表達式,我需要將所有正則表達式匹配到一行,並且需要找出匹配的女巫正則表達式。
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))
但是您必須搜索兩次,這很浪費。 如上所示,您可以通過在模式上循環來避免這種情況。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.