我有以下字符串

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

10-07 13:38