【Python】在使用联网工具时需要的问题

LangChain 的 Agent 默认逻辑是"尽力而为",如果工具报错或返回空,它往往会认为"我还需要更多信息",从而陷入死循环或者幻觉(开始编造答案)。

要控制它在搜索失败后立即停止并返回特定结果,你需要从以下三个层面进行"约束":

1. 工具层:封装"失败信号"

不要让 Agent 直接接收原始的错误堆栈信息(如 ConnectionError...),这会让它困惑。你需要封装工具,当网络请求失败或结果为空时,明确返回一个特殊的失败标记。

python 复制代码
from langchain_community.tools import DuckDuckGoSearchRun
from langchain.agents import tool

# 1. 定义一个带有容错逻辑的自定义工具
@tool
def safe_search(query: str) -> str:
    """
    用于搜索互联网上的最新信息。
    如果搜索失败或没有找到结果,会返回 'SEARCH_FAILED'。
    """
    try:
        search_tool = DuckDuckGoSearchRun()
        result = search_tool.run(query)
        
        # 2. 增加空结果检查
        if not result or len(result) < 10: # 简单的长度校验
            return "SEARCH_FAILED: 没有找到相关信息"
            
        return result
    except Exception as e:
        # 3. 捕获网络异常,返回明确的信号
        print(f"网络错误: {e}") # 后台打印错误,不让 Agent 看到
        return "SEARCH_FAILED: 网络连接失败或无法访问外部资源"

tools = [safe_search]

2. 提示词层:植入"停止指令"

你需要在 System Prompt 中明确告诉 Agent:"当你看到 SEARCH_FAILED 时,不要重试,直接告诉用户搜索失败。"

python 复制代码
from langchain_core.prompts import ChatPromptTemplate, MessagesPlaceholder

# 关键:在 System Message 中加入防御性指令
system_msg = """
你是一个有用的助手。你可以使用以下工具:
{tools}

重要规则:
1. 如果工具返回 "SEARCH_FAILED" 或 "没有找到相关信息",请**立即停止**尝试搜索。
2. 不要尝试更换关键词再次搜索,也不要编造答案。
3. 直接回复用户:"抱歉,由于网络原因或资料缺失,我无法找到关于该主题的信息。"
"""

prompt = ChatPromptTemplate.from_messages([
    ("system", system_msg),
    ("human", "{input}"),
    MessagesPlaceholder(variable_name="agent_scratchpad"), 
])

3. 执行层:设置"硬性熔断"

为了防止 Agent 因为"幻觉"而无视指令继续死循环,必须在 AgentExecutor 中设置最大迭代次数。这是最后一道防线。

python 复制代码
from langchain_classic.agents import AgentExecutor

agent_executor = AgentExecutor(
    agent=agent, 
    tools=tools, 
    verbose=True, 
    handle_parsing_errors=True,
    
    # 核心配置:
    max_iterations=3,  # 限制最多只能尝试 3 步(思考-行动)。超过则强制停止。
    max_execution_time=30, # 限制总执行时间(秒),防止无限卡在网络请求上
)

4. 执行层:设置"硬性熔断"

为了防止 Agent 因为"幻觉"而无视指令继续死循环,必须在 AgentExecutor 中设置最大迭代次数。这是最后一道防线。

python 复制代码
from langchain_classic.agents import AgentExecutor

agent_executor = AgentExecutor(
    agent=agent, 
    tools=tools, 
    verbose=True, 
    handle_parsing_errors=True,
    
    # 核心配置:
    max_iterations=3,  # 限制最多只能尝试 3 步(思考-行动)。超过则强制停止。
    max_execution_time=30, # 限制总执行时间(秒),防止无限卡在网络请求上
)
相关推荐
想唱rap2 小时前
线程的同步与互斥
linux·运维·服务器·数据库·mysql
小白菜又菜2 小时前
Leetcode 657. Robot Return to Origin
python·leetcode·职场和发展
2402_881319302 小时前
跨服务通信兜底机制-Java 回传失败无持久重试队列,报告可能静默丢失。
java·开发语言·python
jwn9992 小时前
Laravel5.x核心特性全解析
android·php·laravel
勇闯逆流河2 小时前
【LInux】linux控制(进程替换,自主shell的实现详解)
linux·运维·服务器
IMPYLH3 小时前
Linux 的 ls 命令
linux·运维·服务器·bash
笨笨饿3 小时前
33_顺序表(待完善)
linux·服务器·c语言·嵌入式硬件·算法·学习方法
自信不孤单3 小时前
UniAda核心代码详解
python·ai·大模型·tta·狄利克雷理论·证据感知
smj2302_796826523 小时前
解决leetcode第3883题统计满足数位和数组的非递减数组数目
python·算法·leetcode