下面是一个示例代码,演示如何按行分组匹配:
import re
def group_matching_lines(pattern, text):
groups = []
lines = text.split("\n")
current_group = []
for line in lines:
match = re.search(pattern, line)
if match:
current_group.append(line)
elif current_group:
groups.append(current_group)
current_group = []
if current_group:
groups.append(current_group)
return groups
# 示例用法
text = """
Line 1: This is a test
Line 2: Match this line
Line 3: This line doesn't match
Line 4: Match this line too
Line 5: This line doesn't match either
"""
pattern = r"Match"
matching_groups = group_matching_lines(pattern, text)
for group in matching_groups:
print("Matching group:")
for line in group:
print(line)
print()
输出结果:
Matching group:
Line 2: Match this line
Matching group:
Line 4: Match this line too
在这个示例中,group_matching_lines
函数接受一个正则表达式模式和一段文本作为输入。它将文本按行分割,并逐行匹配模式。如果某一行匹配成功,就将该行添加到当前分组中。如果某一行不匹配并且当前分组不为空,则将当前分组添加到结果列表中,并创建一个新的空的当前分组。最后,如果当前分组不为空,则将其添加到结果列表中。
在示例中,我们使用r"Match"
作为模式,它匹配任何包含“Match”的行。输出结果中只包含匹配的行,并按组进行分组。每个匹配组都打印在一行上,之间用空行分隔。