如何解决正则表达式搜索并grep字符串中第一个关键字和第二个关键字的第二次出现之间的所有内容 - Python
example_string = 'Hello A Bye,Hello B Ciao."
通缉:"B"
我想用什么:re.search()
常规方法:
res = re.search(r'Hello(.*?)Ciao',example_string)
有没有办法告诉程序第二次出现第一个关键字。因此,在这种情况下,它将搜索字符串中第二次出现的单词“Hello”,并将其作为 res
中的第一个关键字。
这样它就会简单地输出:"B"
。
有人知道如何解决这个问题吗?
谢谢。
解决方法
我们可以在这里使用 re.findall
查找所有匹配项,然后访问第二个匹配项:
example_string = "Hello A Bye,Hello B Ciao."
matches = re.findall(r'\bHello (\w+)',example_string)
print(matches[1]) # B
,
使用 re.findall
可以工作,findall() 可能是 re 模块中最强大的函数。上面我们使用 re.search() 来查找模式的第一个匹配项。 findall() 查找 all 匹配项并将它们作为字符串列表返回,每个字符串代表一个匹配项。
示例:-
text = "He was carefully disguised but captured quickly by police."
>>> re.findall(r"\w+ly",text)
>>> ['carefully','quickly']
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。