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