6 种 Agent 类型的完整可运行代码

1.ZERO_SHOT_REACT_DESCRIPTION

python 复制代码
from langchain_openai import ChatOpenAI
from langchain_core.tools import tool
from langchain_community.agent_toolkits.load_tools import load_tools
from langchain_classic.agents import initialize_agent
import os
import re
from dotenv import load_dotenv
load_dotenv()

# 定义LLM
llm = ChatOpenAI(
    model="glm-4-flash",
    temperature=0.7,
    max_tokens=4096,
    api_key=os.getenv("ZHIPUAI_API_KEY"),
    base_url="https://open.bigmodel.cn/api/paas/v4/"
)

os.environ['SERPAPI_API_KEY'] = '723a13895923198c86b781d6a24803faa6db54ea823506acb006697df2cee910'

# 自定义计算器工具
@tool
def calculator(expression: str) -> str:
    """用于执行数学计算。输入是一个数学表达式,例如:'78 ** 2' 或 '81 * 81'"""
    try:
        clean_expr = re.sub(r'[^0-9+\-*/().** ]', '', expression)
        clean_expr = clean_expr.strip()
        result = eval(clean_expr)
        return str(result)
    except Exception as e:
        return f"计算错误: {e},请检查表达式格式"

# 加载工具
search_tools = load_tools(["serpapi"], llm=llm)
tools = search_tools + [calculator]

agent = initialize_agent(
    tools,
    llm,
    agent_type="zero-shot-react-description",
    verbose=True,
    handle_parsing_errors=True,
    max_iterations=12,
    agent_kwargs={
        "prefix": "你是一个有用的中文助手,可以搜索信息和做数学计算。请始终用中文回答。当前日期是2026年5月7日。"
    }
)

result = agent.invoke({"input": "请问现任的美国总统的是谁,他的年龄的平方是多大"})
print(result["output"])

2.CHAT_ZERO_SHOT_REACT_DESCRIPTION

python 复制代码
from langchain_openai import ChatOpenAI
from langchain_core.tools import tool
from langchain_community.agent_toolkits.load_tools import load_tools
from langchain_classic.agents import initialize_agent
import os
import re
from dotenv import load_dotenv
load_dotenv()

# 定义LLM
llm = ChatOpenAI(
    model="glm-4-flash",
    temperature=0.7,
    max_tokens=4096,
    api_key=os.getenv("ZHIPUAI_API_KEY"),
    base_url="https://open.bigmodel.cn/api/paas/v4/"
)

os.environ['SERPAPI_API_KEY'] = '723a13895923198c86b781d6a24803faa6db54ea823506acb006697df2cee910'

# 自定义计算器工具
@tool
def calculator(expression: str) -> str:
    """用于执行数学计算。输入是一个数学表达式,例如:'78 ** 2' 或 '81 * 81'"""
    try:
        clean_expr = re.sub(r'[^0-9+\-*/().** ]', '', expression)
        clean_expr = clean_expr.strip()
        result = eval(clean_expr)
        return str(result)
    except Exception as e:
        return f"计算错误: {e},请检查表达式格式"

# 加载工具
search_tools = load_tools(["serpapi"], llm=llm)
tools = search_tools + [calculator]

agent = initialize_agent(
    tools,
    llm,
    agent_type="chat-zero-shot-react-description",
    verbose=True,
    handle_parsing_errors=True,
    max_iterations=12,
    agent_kwargs={
        "system_message": "你是一个有用的中文助手,可以搜索信息和做数学计算。请始终用中文回答。当前日期是2026年5月7日。"
    }
)

result = agent.invoke({"input": "请问现任的美国总统的是谁,他的年龄的平方是多大"})
print(result["output"])

3.CONVERSATIONAL_REACT_DESCRIPTION

python 复制代码
from langchain_openai import ChatOpenAI
from langchain_core.tools import tool
from langchain_community.agent_toolkits.load_tools import load_tools
from langchain.agents import create_agent
from langgraph.checkpoint.memory import InMemorySaver
import os
import re
from dotenv import load_dotenv
load_dotenv()

# 定义LLM
llm = ChatOpenAI(
    model="glm-4-flash",
    temperature=0.7,
    max_tokens=4096,
    api_key=os.getenv("ZHIPUAI_API_KEY"),
    base_url="https://open.bigmodel.cn/api/paas/v4/"
)

os.environ['SERPAPI_API_KEY'] = '723a13895923198c86b781d6a24803faa6db54ea823506acb006697df2cee910'

# 自定义计算器工具
@tool
def calculator(expression: str) -> str:
    """用于执行数学计算。输入是一个数学表达式,例如:'78 ** 2' 或 '81 * 81'"""
    try:
        clean_expr = re.sub(r'[^0-9+\-*/().** ]', '', expression)
        clean_expr = clean_expr.strip()
        result = eval(clean_expr)
        return str(result)
    except Exception as e:
        return f"计算错误: {e},请检查表达式格式"

# 加载工具
search_tools = load_tools(["serpapi"], llm=llm)
tools = search_tools + [calculator]

# 创建记忆(新版方式)
checkpointer = InMemorySaver()

agent = create_agent(
    model=llm,
    tools=tools,
    system_prompt="""你是一个有用的中文助手,可以搜索信息和做数学计算。
规则:
1. 始终用中文回答
2. 如果用户问需要计算的问题,必须使用 calculator 工具进行计算
3. 当前日期是2026年5月7日
4. 如果用户问的是上一轮提到的人物,直接使用上一轮的信息,不需要重新搜索""",
    checkpointer=checkpointer,
)

# 使用 thread_id 来区分对话,同一个 thread_id 会记住之前的对话
config = {"configurable": {"thread_id": "1"}}

# 第一轮对话
result1 = agent.invoke(
    {"messages": [{"role": "user", "content": "请问现任的美国总统的是谁,他的年龄的平方是多大"}]},
    config=config
)
print("第一轮:", result1["messages"][-1].content)

# 第二轮对话(同一个 thread_id,会记住上一轮)
result2 = agent.invoke(
    {"messages": [{"role": "user", "content": "他的年龄是多大"}]},
    config=config
)
print("第二轮:", result2["messages"][-1].content)

4.CHAT_CONVERSATIONAL_REACT_DESCRIPTION(多轮对话)

python 复制代码
# CHAT_CONVERSATIONAL_REACT_DESCRIPTION.py
from langchain_openai import ChatOpenAI
from langchain_core.tools import tool
from langchain_community.agent_toolkits.load_tools import load_tools
from langchain.agents import create_agent
from langgraph.checkpoint.memory import InMemorySaver
import os
import re
from dotenv import load_dotenv
load_dotenv()

# 定义LLM
llm = ChatOpenAI(
    model="glm-4-flash",
    temperature=0.7,
    max_tokens=4096,
    api_key=os.getenv("ZHIPUAI_API_KEY"),
    base_url="https://open.bigmodel.cn/api/paas/v4/"
)

os.environ['SERPAPI_API_KEY'] = '723a13895923198c86b781d6a24803faa6db54ea823506acb006697df2cee910'

# 自定义计算器工具
@tool
def calculator(expression: str) -> str:
    """用于执行数学计算。输入是一个数学表达式,例如:'78 ** 2' 或 '81 * 81'"""
    try:
        clean_expr = re.sub(r'[^0-9+\-*/().** ]', '', expression)
        clean_expr = clean_expr.strip()
        result = eval(clean_expr)
        return str(result)
    except Exception as e:
        return f"计算错误: {e},请检查表达式格式"

# 加载工具
search_tools = load_tools(["serpapi"], llm=llm)
tools = search_tools + [calculator]

# 创建记忆(新版方式)
checkpointer = InMemorySaver()

# 创建 Agent
agent = create_agent(
    model=llm,
    tools=tools,
    system_prompt="""你是一个有用的中文助手,可以搜索信息和做数学计算。

规则:
1. 始终用中文回答
2. 需要计算时,必须使用 calculator 工具
3. 当前日期是2026年5月7日
4. 用户提到"他""她"等代词时,指的是上一轮对话中提到的人物
5. 如果上一轮已经找到了人物信息(如年龄),直接使用,不需要重新搜索""",
    checkpointer=checkpointer,
)

# 使用 thread_id 来区分对话
config = {"configurable": {"thread_id": "1"}}

# 第一轮
print("=" * 50)
print("用户:请问现任的美国总统是谁")
print("=" * 50)
result1 = agent.invoke(
    {"messages": [{"role": "user", "content": "请问现任的美国总统是谁"}]},
    config
)
print("Agent:", result1["messages"][-1].content)

# 第二轮(测试记忆)
print("=" * 50)
print("用户:他的年龄的平方是多大")
print("=" * 50)
result2 = agent.invoke(
    {"messages": [{"role": "user", "content": "他的年龄的平方是多大"}]},
    config
)
print("Agent:", result2["messages"][-1].content)

# 第三轮(继续测试记忆)
print("=" * 50)
print("用户:他出生在哪一年")
print("=" * 50)
result3 = agent.invoke(
    {"messages": [{"role": "user", "content": "他出生在哪一年"}]},
    config
)
print("Agent:", result3["messages"][-1].content)

5.OPENAI_FUNCTIONS

python 复制代码
# OPENAI_FUNCTIONS.py
from langchain_openai import ChatOpenAI
from langchain_core.tools import tool
from langchain_community.agent_toolkits.load_tools import load_tools
from langchain_classic.agents import initialize_agent
import os
import re
from dotenv import load_dotenv
load_dotenv()

# 定义LLM
llm = ChatOpenAI(
    model="glm-4-flash",
    temperature=0.7,
    max_tokens=4096,
    api_key=os.getenv("ZHIPUAI_API_KEY"),
    base_url="https://open.bigmodel.cn/api/paas/v4/"
)

os.environ['SERPAPI_API_KEY'] = '723a13895923198c86b781d6a24803faa6db54ea823506acb006697df2cee910'

# 自定义计算器工具
@tool
def calculator(expression: str) -> str:
    """用于执行数学计算。输入是一个数学表达式,例如:'78 ** 2' 或 '81 * 81'"""
    try:
        clean_expr = re.sub(r'[^0-9+\-*/().** ]', '', expression)
        clean_expr = clean_expr.strip()
        result = eval(clean_expr)
        return str(result)
    except Exception as e:
        return f"计算错误: {e},请检查表达式格式"

# 加载工具
search_tools = load_tools(["serpapi"], llm=llm)
tools = search_tools + [calculator]

# 创建 Agent
agent = initialize_agent(
    tools,
    llm,
    agent_type="openai-functions",
    verbose=True,
    handle_parsing_errors=True,
    max_iterations=8,
)

# 调用
print("=" * 50)
print("用户:请问现任的美国总统的是谁,他的年龄的平方是多大")
print("=" * 50)
result = agent.invoke({"input": "请问现任的美国总统的是谁,他的年龄的平方是多大"})
print("Agent:", result["output"])

6.STRUCTURED_CHAT_ZERO_SHOT_REACT_DESCRIPTION

python 复制代码
# STRUCTURED_CHAT_ZERO_SHOT_REACT_DESCRIPTION.py
from langchain_openai import ChatOpenAI
from langchain_core.tools import tool
from langchain_community.agent_toolkits.load_tools import load_tools
from langchain_classic.agents import initialize_agent
import os
import re
from dotenv import load_dotenv
load_dotenv()

# 定义LLM
llm = ChatOpenAI(
    model="glm-4-flash",
    temperature=0.7,
    max_tokens=4096,
    api_key=os.getenv("ZHIPUAI_API_KEY"),
    base_url="https://open.bigmodel.cn/api/paas/v4/"
)

os.environ['SERPAPI_API_KEY'] = '723a13895923198c86b781d6a24803faa6db54ea823506acb006697df2cee910'

# 自定义计算器工具
@tool
def calculator(expression: str) -> str:
    """用于执行数学计算。输入是一个数学表达式,例如:'78 ** 2' 或 '81 * 81'"""
    try:
        clean_expr = re.sub(r'[^0-9+\-*/().** ]', '', expression)
        clean_expr = clean_expr.strip()
        result = eval(clean_expr)
        return str(result)
    except Exception as e:
        return f"计算错误: {e},请检查表达式格式"

# 加载工具
search_tools = load_tools(["serpapi"], llm=llm)
tools = search_tools + [calculator]

# 创建 Agent
agent = initialize_agent(
    tools,
    llm,
    agent_type="structured-chat-zero-shot-react-description",
    verbose=True,
    handle_parsing_errors=True,
    max_iterations=8,
)

# 调用(注意:输入格式需要嵌套一层)
print("=" * 50)
print("用户:请问现任的美国总统的是谁,他的年龄的平方是多大")
print("=" * 50)
result = agent.invoke({"input": {"input": "请问现任的美国总统的是谁,他的年龄的平方是多大"}})
print("Agent:", result["output"])

7.总结

第3个和第4个的区别

第3个 CONVERSATIONAL_REACT_DESCRIPTION 最初是为补全模型 (用 OpenAI 类调用的模型)设计的,它会把对话历史拼接成一段连续的文本喂给模型,比如把历史拼成 "用户:你好\n助手:你好\n用户:他多大了" 这样一整段文字,模型在此基础上续写回答。

第4个 CHAT_CONVERSATIONAL_REACT_DESCRIPTION 是为对话模型 (用 ChatOpenAI 类调用的模型)设计的,它会把对话历史按角色拆分成结构化的消息列表,比如 [{"role": "user", "content": "你好"}, {"role": "assistant", "content": "你好"}, {"role": "user", "content": "他多大了"}],模型按照系统、用户、助手的角色分别理解上下文。

但在实际使用中,如果你用的是 ChatOpenAI(不管是智谱、通义还是 OpenAI),两者的效果几乎没有区别。 因为新版 create_agent 会自动处理格式转换,不需要你手动区分。所以你只需要记住:需要多轮对话记忆就用 create_agent + InMemorySaver,不需要纠结选第3个还是第4个。

相关推荐
纪伊路上盛名在2 小时前
机器学习中常见的距离度量函数 Distance metrics
人工智能·算法·机器学习·数据分析·统计
美团技术团队2 小时前
用Agent评测思路管理AI Coding —— 31万行代码AI重构的实践
人工智能
OpenCSG2 小时前
AI 不再只是聊天机器人:企业为什么开始构建自己的 Agent 系统?
人工智能·机器人
经济元宇宙2 小时前
哪款工业仿真软件上手简单?企业常用款推荐
人工智能·算法
大侠区块链3 小时前
我面试了上百个想进 AI 公司的人,发现他们都搞错了一件事--深度精读 | 对话 Anthropic Claude Code 产品负责人 Cat Wu
人工智能·面试·职场和发展
绿虫光伏运维3 小时前
光伏运维精细化管理,解锁电站收益最大化
大数据·运维·人工智能·光伏业务
小仙女的小稀罕3 小时前
适合销售从业者会议整理使用的销售录音转任务工具
大数据·人工智能·学习·自然语言处理·语音识别
GitCode官方3 小时前
头号 Builder 集结|出海 Agent 开造!大疆 Pocket4 等你赢!
人工智能·agent·atomgit
CIO_Alliance3 小时前
2026年生成式引擎优化(GEO)解决方案选型指南|幂链科技的实战可验证与全链路合规
人工智能·geo·deepseek·ai搜索优化·幂链geo·豆包ai