( 教学 )Agent 构建 Prompt(提示词)2. CommaSeparatedListOutputParser

CommaSeparatedListOutputParser

CommaSeparatedListOutputParser逗号分隔列表输出解析器 是 LangChain中的一种专门的输出解析器,用于以逗号分隔列表的形式生成结构化输出。

它简化了提取和以清晰简洁的列表形式呈现数据的过程,特别适用于组织诸如数据点、名称、项目或其他结构化值等信息。通过利用这个解析器,用户可以提高数据的清晰度、确保格式的一致性,并提高工作流程的效率,尤其是在需要生成结构化输出的应用中。

如何使用 CommaSeparatedListOutputParser:

  1. 设置并初始化用于生成以逗号分隔列表的解析器
  2. 将其与提示模板和语言模型相结合
  3. 通过流式机制对结构化输出进行迭代处理

实现 CommaSeparatedListOutputParser

如果你需要生成以逗号分隔的列表形式的输出,LangChainCommaSeparatedListOutputParser可以简化这个过程。

以下是逐步实现的方法:

1. 导入所需模块

首先导入必要的模块并初始化 CommaSeparatedListOutputParser

从解析器中获取格式化指令以指导输出结构。

python 复制代码
from langchain.output_parsers import CommaSeparatedListOutputParser

# 初始化解析器
output_parser = CommaSeparatedListOutputParser()

# 获取格式化指令
format_instructions = output_parser.get_format_instructions()

2. 创建提示模板

定义一个PromptTemplate来动态生成项目列表。

占位符主题将在执行过程中被替换为所需的主题。

python 复制代码
from langchain_core.prompts import PromptTemplate

# 定义提示模板
prompt = PromptTemplate(
    template="列出五个{subject}。\n {format_instructions}",
    input_variables=["subject"],  # 'subject' 将在运行时被动态替换
    partial_variables={
        "format_instructions": format_instructions
    },  # 使用解析器的格式说明
)
print(prompt)

结果

复制代码
input_variables=['subject'] 
input_types={} 
partial_variables={'format_instructions': 'Your response should be a list of comma separated values, eg: `foo, bar, baz` or `foo,bar,baz`'} 
template='列出五个{subject}。\n{format_instructions}'

3. 集成 ChatOpenAI并运行链式调用

PromptTemplateChatOpenAI模型和 CommaSeparatedListOutputParser组合成一个链式调用。最后,使用特定的 subject运行该链式调用以生成结果。

python 复制代码
from langchain_openai import ChatOpenAI
from dotenv import load_dotenv
import os

load_dotenv()
Qwen2_5_7B_Instruct_llm = ChatOpenAI(
    temperature=0.1,  # 控制输出的随机性和创造性,值越低输出越稳定可预测,值越高输出越有创意但可能偏离预期 (范围: 0.0 ~ 2.0)
    model_name="Qwen/Qwen2.5-7B-Instruct",  # 硅基流动支持的模型名称
    openai_api_key=os.getenv("SILICONFLOW_API_KEY"),  # 从环境变量获取API密钥
    openai_api_base="https://api.siliconflow.cn/v1"  # 硅基流动API的基础URL
)
# 将提示、模型和输出解析器组合成链
chain = prompt | Qwen2_5_7B_Instruct_llm | output_parser

# 使用特定主题运行链
result = chain.invoke({"subject": "中国著名地标"})
print(result)

测试结果:

复制代码
['北京', '上海', '广州', '深圳', '成都']

4. 使用Python索引访问数据

由于 CommaSeparatedListOutputParser会自动将输出格式化为Python列表,你可以轻松地使用索引来访问单个元素。

例如,要访问列表中的第一个元素(北京),可以使用 result[0]

python 复制代码
print("第一个地标:", result[0])
print("第二个地标:", result[1])
print("最后一个地标:", result[-1])

测试结果:

复制代码
第一个地标: 北京
第二个地标: 上海
最后一个地标: 成都

使用流式输出

对于较大的输出或需要实时反馈的情况,你可以使用 stream方法来处理结果。这使你能够在数据生成时逐段处理数据。

python 复制代码
for output in chain.stream({"subject": "中国著名地标"}):
    print(output)

测试结果:

复制代码
[北京]
[上海]
[广州]
[深圳]
[成都]

应用方向

  • 数据提取:从文本中提取结构化数据,如姓名、地址、日期等。

  • 内容分类:将文本分类为不同的主题或类别。

  • 自动摘要:生成文本的摘要或关键词。

  • 问答系统:构建基于文本的问答系统,回答用户问题。

    成都

    应用方向

    • 数据提取:从文本中提取结构化数据,如姓名、地址、日期等。
    • 内容分类:将文本分类为不同的主题或类别。
    • 自动摘要:生成文本的摘要或关键词。
    • 问答系统:构建基于文本的问答系统,回答用户问题。
    • 内容生成:根据用户输入或主题生成新的文本内容。
相关推荐
志栋智能几秒前
超越监控:超自动化巡检提供的主动价值
运维·网络·人工智能·自动化
SunnyDays10116 分钟前
Python操作Excel批注:从基础添加到高级自定义的完整指南
开发语言·python·excel
Elastic 中国社区官方博客11 分钟前
Elastic 线下 Meetup 将于 2026 年 7 月 26 号下午在深圳举行
大数据·数据库·人工智能·elasticsearch·搜索引擎·ai·全文检索
独隅15 分钟前
PyTorch自动微分模块:从原理到实战一
人工智能·pytorch·python
code_pgf16 分钟前
ViT 与 MAE 在图像特征提取方面的优势详解
人工智能·stable diffusion
feifeigo12319 分钟前
基于隐马尔可夫模型(HMM)的孤立词语音识别系统
人工智能·语音识别·xcode
weixin_4684668529 分钟前
千问大模型在阿里生态中的实战应用指南
大数据·人工智能·深度学习·ai·大模型·智能交互·自动应答
kTR2hD1qb43 分钟前
Claude Code Skill的介绍与使用
java·前端·数据库·人工智能
qq_3909347444 分钟前
Cursor使用教程
人工智能
码农小白AI1 小时前
规范档案复核流程,IACheck+AI 报告审核满足资质监管要求
人工智能