使用 python regex 查找所有出现的多个 regex 条件

给定 2 种不同的正则表达式模式,我想找到这 2 种模式的所有出现。如果只有模式 1 匹配,则返回,如果只有模式 2 匹配,则返回,如果模式 1 和模式 2 匹配,则返回两者。那么我如何在一个语句中运行多个(在本例中为 2 个正则表达式)?


给定输入字符串:


"https://test.com/change-password?secret=12345;email=test@gmail.com;previous_password=hello;new=1"

我只想获得电子邮件和秘密的价值。所以我希望输出为['12345', 'test@gmail.com']


import re

print(re.search(r"(?<=secret=)[^;]+", s).group())

print(re.search(r"(?<=email=)[^;]+", s).group())

我可以通过多次运行正则表达式来获得预期的输出。我如何在单个语句中实现它?我不想运行 re.search 2 次。我可以在一个搜索语句中实现这一目标吗?


三国纷争
浏览 164回答 3
3回答

萧十郎

>>> re.findall(r"((?:(?<=email=)|(?<=secret=))[^;]+)", s)['12345', 'test@gmail.com']但是现在您需要一种方法来识别哪些结果值是秘密,哪些是电子邮件。我建议还使用正则表达式提取此信息(这也消除了后视):>>> dict(kv.split('=') for kv in re.findall(r"((?:secret|email)=[^;]+)", s)){'secret': '12345', 'email': 'test@gmail.com'}

守着星空守着你

import reprint(re.findall("(?<=secret=)[^;]+|(?<=email=)[^;]+", s))# output# ['12345', 'test@gmail.com']

翻翻过去那场雪

您可以使用 dict 理解:import reurl = "https://test.com/change-password?secret=12345;email=test@gmail.com;previous_password=hello;new=1"rx = re.compile(r'(?P<key>\w+)=(?P<value>[^;]+)')dict_ = {m['key']: m['value'] for m in rx.finditer(url)}# ... then afterwards ...lst_ = [value for key in ("secret", "email") if key in dict_ for value in [dict_[key]]]print(lst_)# ['12345', 'test@gmail.com']
打开App,查看更多内容
随时随地看视频慕课网APP

相关分类

Python