我有以下字符串
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']