python - 正则表达式。查找多次出现的模式

标签 python regex

我有以下字符串

my_string = "this data is F56 F23 and G87"

我想使用正则表达式返回以下输出

['F56 F23', 'G87']

基本上,我感兴趣的是返回字符串中以 F 或 G 开头并后跟两个数字的所有部分。此外,如果有多个连续出现,我希望正则表达式将它们组合在一起。

我用 python 和这段代码解决了这个问题

import re
re.findall(r'\b(F\d{2}|G\d{2})\b', my_string)

我能够得到所有的事件

['F56', 'F23', 'G87']

但我希望将前两组放在一起,因为它们是连续出现的。关于如何实现这一目标的任何想法?

最佳答案

你可以使用这个正则表达式:

\b[FG]\d{2}(?:\s+[FG]\d{2})*\b

非捕获组 (?:\s+[FG]\d{2})* 将找到零个或多个以下空格分隔的 F/G 子字符串。

代码:

>>> my_string = "this data is F56 F23 and G87"
>>> re.findall(r'\b[FG]\d{2}(?:\s+[FG]\d{2})*\b', my_string)
['F56 F23', 'G87']

关于python - 正则表达式。查找多次出现的模式,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43983614/

相关文章:

python - 根据条件删除列表的元素

python - 正则表达式:匹配括号贪婪和非贪婪

java - Log4j2 正则表达式

vb.net - 如何正则表达式替换命名组

regex - 匹配有限自然数级数

Python-elasticsearch.exceptions.RequestError

python解码fernet key

python - 安装 Google Assistant 时,我报错 "...googlesamples.assistant' 是一个包,无法直接执行...”

python - 使用 subprocess 模块的字符串参数

regex - Perl 负向前视表示不匹配单词