为了账号安全,请及时绑定邮箱和手机立即绑定

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

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

三国纷争 2022-06-07 19:58:29
给定 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 reprint(re.search(r"(?<=secret=)[^;]+", s).group())print(re.search(r"(?<=email=)[^;]+", s).group())我可以通过多次运行正则表达式来获得预期的输出。我如何在单个语句中实现它?我不想运行 re.search 2 次。我可以在一个搜索语句中实现这一目标吗?
查看完整描述

3 回答

?
萧十郎

TA贡献1815条经验 获得超13个赞

>>> 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'}


查看完整回答
反对 回复 2022-06-07
?
守着星空守着你

TA贡献1799条经验 获得超8个赞

import re


print(re.findall("(?<=secret=)[^;]+|(?<=email=)[^;]+", s))


# output

# ['12345', 'test@gmail.com']


查看完整回答
反对 回复 2022-06-07
?
翻翻过去那场雪

TA贡献2065条经验 获得超14个赞

您可以使用 dict 理解:


import re

url = "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']


查看完整回答
反对 回复 2022-06-07
  • 3 回答
  • 0 关注
  • 161 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信