python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python groups()

浅谈Python正则表达式中的groups()

作者:青衫客36

本文介绍了Python中正则表达式re模块的groups()方法,通过解析智能体动作指令的实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

在使用 Python 进行文本解析时,正则表达式(re 模块)是最常用的工具之一。尤其是在智能体(Agent)开发、日志分析、命令解析等场景中,我们常常需要通过正则捕获一段字符串的不同部分。

其中,Match 对象的 groups() 方法 是一个非常实用的接口,可以一次性获取所有括号捕获到的内容。本文将通过一个具体示例,讲解 groups() 的作用与用法。

1. 基础概念

在 Python 的 re 模块中:

例如:

import re

pattern = re.compile(r"(\d+)-(\d+)")
m = pattern.match("123-456")

print(m.group(1))   # 123
print(m.group(2))   # 456
print(m.groups())   # ('123', '456')

这里 ( \d+ )( \d+ ) 分别捕获了 "123""456"groups() 会把它们打包成 ('123', '456')

2. 实际应用场景:解析智能体的动作指令

假设我们在实现一个 ReAct 风格的智能体,大模型会输出类似这样的内容:

Action: wikipedia: India

这里包含三个部分:

我们希望用正则把它拆开,分别提取出工具名和输入。

定义正则表达式:

import re

action_re = re.compile(r"^Action: (\w+): (.*)$")

解释:

3. 匹配与groups()输出

text = "Action: wikipedia: India"
m = action_re.match(text)

print("完整匹配:", m.group(0))   # Action: wikipedia: India
print("group(1):", m.group(1))  # wikipedia
print("group(2):", m.group(2))  # India
print("groups():", m.groups())  # ('wikipedia', 'India')

输出结果:

完整匹配: Action: wikipedia: India
group(1): wikipedia
group(2): India
groups(): ('wikipedia', 'India')

在实际代码中,可以直接用 解构赋值

action, action_input = m.groups()
print(action)       # wikipedia
print(action_input) # India

4. 直观图解

匹配过程可以用下图表示:

Action: wikipedia: India
       |-------|   |----|
       group(1)   group(2)

5. 总结

掌握 groups(),就能够方便地写出更加简洁、清晰的解析逻辑,从而为构建智能体、命令解析器、日志处理程序打下坚实的基础。

到此这篇关于浅谈Python正则表达式中的groups()的文章就介绍到这了,更多相关Python groups()内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文