【自然语言处理与大模型】LangChainV1.0入门指南:核心组件Agent

本文介绍langchain如何快速搭建ReAct范式的智能体。

LangChain Agents 是基于 LangGraph 构建的,以提供持久执行、流式处理、人机交互、持久化存储等功能。但对于基本的 LangChain Agent 使用是无需了解 LangGraph。

一、如何创建Agent

创建Agent超级简单!!使用create_agent搞定!

python 复制代码
# 从 dotenv 模块导入 load_dotenv 函数
# 用于从项目根目录下的 .env 文件中加载环境变量(如 API 密钥)
from dotenv import load_dotenv

# 加载 .env 文件中的环境变量,并覆盖系统中已存在的同名变量
# 这样可以安全地管理敏感信息(例如 ZHIPUAI_API_KEY),避免硬编码在代码中
load_dotenv(override=True)


# 从 langchain.agents 模块导入 create_agent 工具函数
# 该函数用于快速创建一个具备特定行为的智能体(Agent)
from langchain.agents import create_agent

# 从 langchain_community.chat_models 导入 ChatZhipuAI
# 这是 LangChain 对智谱 AI(ZhipuAI)大模型的官方封装,支持 GLM 系列模型
from langchain_community.chat_models import ChatZhipuAI


# ========================
# 1. 初始化大语言模型(LLM)
# ========================
# 创建一个 ChatZhipuAI 模型实例,指定使用 "glm-4.5-flash" 模型
# 该模型是智谱推出的高性能、低延迟轻量级大模型,适合快速响应场景
# 注意:API Key 会自动从环境变量 ZHIPUAI_API_KEY 中读取,无需手动传入
model = ChatZhipuAI(
    model="glm-4.5-flash"
)


# ========================
# 2. 创建智能体(Agent)
# ========================
# 使用 create_agent 函数构建一个具备特定角色和行为的智能体
agent = create_agent(
    model=model,  # 指定智能体所依赖的大语言模型(此处为 GLM-4.5-Flash)
    
    tools=[],     # 指定智能体可用的工具列表(如搜索、计算器、数据库等)
                  # 注意:tools 参数是必填项,即使不使用任何工具,也必须传入一个空列表 []
                  # 若后续需要扩展功能(如联网查询),可在此添加 Tool 实例
    
    system_prompt="你是一个答案之书,人们向你倾述最近困扰的事情,你给予简短的答案。"
                  # 设置系统级提示词(System Prompt),用于定义智能体的角色、语气和行为规范
                  # 此处设定其为"答案之书"------提供简洁、有哲理的回应,类似人生指南
)

① env 文件应包含

复制代码
ZHIPUAI_API_KEY=your_zhipu_api_key_here

LangChain 会自动读取该变量,无需在代码中显式传递。

② 关于 tools=[]

  • 当前智能体不具备外部工具调用能力,仅能基于自身知识回答。
  • 若未来想让 Agent 调用函数(如查天气、算数学),需在此传入 Tool 对象列表。

二、如何使用Agent

python 复制代码
# 智能体只接受这种方式的输入。
inputs = {"messages": [{"role": "user", "content": "我不知道怎么才能考上大学"}]}

# 调用智能体
response = agent.invoke(inputs)

# 让我们来看看智能体返回的内容是什么?
print(response)

# 是一个字典
print(type(response))

# 里面只有一个消息列表
print(response.keys())
相关推荐
2501_9444480011 分钟前
Flutter for OpenHarmony衣橱管家App实战:支持我们功能实现
android·javascript·flutter
人工智能训练6 小时前
【极速部署】Ubuntu24.04+CUDA13.0 玩转 VLLM 0.15.0:预编译 Wheel 包 GPU 版安装全攻略
运维·前端·人工智能·python·ai编程·cuda·vllm
会跑的葫芦怪6 小时前
若依Vue 项目多子路径配置
前端·javascript·vue.js
xiaoqi9227 小时前
React Native鸿蒙跨平台如何进行狗狗领养中心,实现基于唯一标识的事件透传方式是移动端列表开发的通用规范
javascript·react native·react.js·ecmascript·harmonyos
jin1233228 小时前
React Native鸿蒙跨平台剧本杀组队消息与快捷入口组件,包含消息列表展示、快捷入口管理、快捷操作触发和消息详情预览四大核心功能
javascript·react native·react.js·ecmascript·harmonyos
烬头88219 小时前
React Native鸿蒙跨平台实现二维码联系人APP(QRCodeContactApp)
javascript·react native·react.js·ecmascript·harmonyos
pas1369 小时前
40-mini-vue 实现三种联合类型
前端·javascript·vue.js
摇滚侠9 小时前
2 小时快速入门 ES6 基础视频教程
前端·ecmascript·es6
2601_949833399 小时前
flutter_for_openharmony口腔护理app实战+预约管理实现
android·javascript·flutter
珑墨10 小时前
【Turbo】使用介绍
前端