简洁版本:
我想创建一个函数,用来自 datadict 的对应数据替换正则表达式中的所有命名组。例如:
Input: expr=r"/(?P<something>\w+)/whatever/(?P<something2>\w+)" data={"something":123, "something2": "thing"}
Output: "/123/whatever/thing"
但我不知道该怎么做。
一些附加信息:
我有代码迭代包含名称和模式的元组列表并尝试使用re.search。如果 re.search 匹配给定的字符串,它会从当前元组和 groupdict() (它是带有来自 re.search 的数据的字典)返回名称。
这是代码
class UrlResolver():
def __init__(self):
self.urls = {}
def parse(self, app, url):
for pattern in self.urls[app]:
data = re.search(pattern[1], url)
if data:
return {"name": pattern[0], "data": data.groupdict()}
现在我想创建函数:
def compose(self, app, name, data):
for pattern in self.url[app]:
if pattern[0] == name:
return string composed from regex expression and data from data dict.
上面的函数应该用来自 datadict 的对应数据替换所有命名组。
解决方案
使用 Hans Then 提供的答案(谢谢!)和其他一些信息是解决方案:
def _group_replacer(data, match):
data_key = match.group(1)
return data[data_key]
expression = r"\([^\(]*<([^<]*)>[^\(]*\)"
expression = re.compile(expression)
reversed = re.sub(expression, partial(_group_replacer, data), string)
函数“部分”可以从 functools 导入