langChain 快速入门

简介: LangChain表达式语言(LCEL)以`|`管道符串联PromptTemplate、大模型与OutputParser三大组件,实现提示工程、推理与结果解析的标准化流水线。本文以翻译助手为例,详解如何用LCEL快速构建端到端可调用AI链,代码简洁、逻辑清晰。(239字)

一、LangChain 表达式语言

在没有 LangChain 之前,你可能需要手动拼接字符串、调用 API、再手动解析返回的文本。LangChain 通过 LCEL(LangChain 表达式语言) 将这些步骤标准化。

一个基础的链通常由三个核心组件组成:

  1. PromptTemplate (提示词模板) 📝:将用户的原始输入格式化为结构化的指令。

  2. Model (模型) 🤖:大语言模型(LLM),负责逻辑推理。

  3. OutputParser (输出解析器) 🔍:将模型返回的字符串清洗或转换成你需要的格式(如 JSON 或纯文本)。

在 LangChain 中,我们使用类似 Unix 管道符的 | 符号将它们串联起来:
链 = 提示词 | 模型 | 解析器

二、示例:构建“翻译助手” (LCEL 基础)

我们将学习如何定义一个简单的模板,并利用 | 符号将它与模型连接,实现自动化的语言转换。

先从翻译助手的核心——提示词模板 (PromptTemplate) 开始。

在 LangChain 中,提示词模板就像是一个“填空题”。它不仅包含你对 AI 的指令,还预留了变量位置,方便我们重复使用。

1. 定义提示词模板 📝

我们要告诉 AI:“你是一个专业的翻译官,请将以下文本从 {source_lang} 翻译成 {target_lang}。”

在代码中,它看起来是这样的(以 Python 为例):

Python

from langchain_core.prompts import ChatPromptTemplate

# 定义模板
system_template = "你是一个专业的翻译官,请将用户输入的文本从 {source_lang} 翻译成 {target_lang}。"
human_template = "{text}"

prompt_template = ChatPromptTemplate.from_messages([
    ("system", system_template),
    ("human", human_template),
])

这里我们使用了 system(系统消息,设定角色)和 human(用户消息,提供具体内容)。


2. 准备模型 (Model) 🤖

接下来我们需要一个“大脑”来执行翻译。在 LangChain 中,我们可以轻松切换不同的模型(如 OpenAI、Anthropic 或国产模型)。

Python

# 假设我们使用 ChatOpenAI(实际使用时需要配置 API Key)
from langchain_openai import ChatOpenAI

model = ChatOpenAI(model="gpt-3.5-turbo")

3. 使用 LCEL 串联 🔗

现在是见证奇迹的时刻!在 LCEL 中,我们使用管道符 | 将它们连接起来:

Python

# 这一行就是 LCEL 的精髓
chain = prompt_template | model

这个 chain 现在就像一个完整的“函数”。当我们调用它时,它会自动把输入填入模板,然后传给模型。

4. 运行你的第一个链 🚀

在 LangChain 中,我们使用 .invoke() 方法来触发这个链。我们将这三个参数放在一个字典(Dictionary)里传进去。

代码看起来是这样的:

Python

# 运行链
response = chain.invoke({
    "source_lang": "中文",
    "target_lang": "英文",
    "text": "你好,今天天气不错。"
})

print(response)

这时候你会发现,模型返回的是一个对象(通常是 AIMessage),里面包含了翻译后的文本,但也包含了一些元数据(比如 token 消耗量)。

5. 引入输出解析器 (Output Parser) 🔍

在大多数情况下,我们只想要翻译后的纯字符串。这时就需要用到 StrOutputParser。它可以把复杂的模型输出直接变成简洁的文本。

Python

from langchain_core.output_parsers import StrOutputParser

parser = StrOutputParser()

现在,我们有了三个组件:

  1. prompt_template (格式化输入)

  2. model (处理逻辑)

  3. parser (清理输出)

6. 完整 LangChain 的链

final_chain = prompt_template | model | parser

这行代码完美展示了 LCEL (LangChain Expression Language) 的简洁之美。

通过加上 parser,整个链的流转变得非常清晰:

  1. PromptTemplate:把你的变量填入模板。

  2. Model:接收格式化后的文本并生成回复。

  3. Parser:从模型回复中提取出纯文本字符串。

现在,当你运行 final_chain.invoke(...) 时,你得到的不再是一个复杂的对象,而是一个直接可以使用的翻译结果字符串

相关文章
|
6天前
|
人工智能 数据可视化 安全
王炸组合!阿里云 OpenClaw X 飞书 CLI,开启 Agent 基建狂潮!(附带免费使用6个月服务器)
本文详解如何用阿里云Lighthouse一键部署OpenClaw,结合飞书CLI等工具,让AI真正“动手”——自动群发、生成科研日报、整理知识库。核心理念:未来软件应为AI而生,CLI即AI的“手脚”,实现高效、安全、可控的智能自动化。
23525 14
王炸组合!阿里云 OpenClaw X 飞书 CLI,开启 Agent 基建狂潮!(附带免费使用6个月服务器)
|
18天前
|
人工智能 JSON 机器人
让龙虾成为你的“公众号分身” | 阿里云服务器玩Openclaw
本文带你零成本玩转OpenClaw:学生认证白嫖6个月阿里云服务器,手把手配置飞书机器人、接入免费/高性价比AI模型(NVIDIA/通义),并打造微信公众号“全自动分身”——实时抓热榜、AI选题拆解、一键发布草稿,5分钟完成热点→文章全流程!
34803 141
让龙虾成为你的“公众号分身” | 阿里云服务器玩Openclaw
|
7天前
|
人工智能 JSON 监控
Claude Code 源码泄露:一份价值亿元的 AI 工程公开课
我以为顶级 AI 产品的护城河是模型。读完这 51.2 万行泄露的源码,我发现自己错了。
4663 20
|
6天前
|
人工智能 API 开发者
阿里云百炼 Coding Plan 售罄、Lite 停售、Pro 抢不到?最新解决方案
阿里云百炼Coding Plan Lite已停售,Pro版每日9:30限量抢购难度大。本文解析原因,并提供两大方案:①掌握技巧抢购Pro版;②直接使用百炼平台按量付费——新用户赠100万Tokens,支持Qwen3.5-Max等满血模型,灵活低成本。
1512 3
阿里云百炼 Coding Plan 售罄、Lite 停售、Pro 抢不到?最新解决方案

热门文章

最新文章