( 教学 )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)

测试结果:

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

应用方向

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

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

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

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

    成都

    应用方向

    • 数据提取:从文本中提取结构化数据,如姓名、地址、日期等。
    • 内容分类:将文本分类为不同的主题或类别。
    • 自动摘要:生成文本的摘要或关键词。
    • 问答系统:构建基于文本的问答系统,回答用户问题。
    • 内容生成:根据用户输入或主题生成新的文本内容。
相关推荐
西柚小萌新5 分钟前
【人工智能:Agent】--6.Langchain工作流
langchain
deephub6 分钟前
Agentic Memory 实践:用 agents.md 实现 LLM 持续学习
人工智能·大语言模型·agent
chen_jared12 分钟前
反对称矩阵的性质和几何意义
人工智能·算法·机器学习
NocoBase20 分钟前
NocoBase 本周更新汇总:支持 Gemini-3 模型
人工智能·开源·零代码·无代码·版本更新
汇智信科25 分钟前
智慧矿山和工业大数据解决方案“安全生产数据综合分析系统
大数据·人工智能·安全·智能算法·智慧矿山·工业大数据·汇智信科
雨大王51229 分钟前
汽车工厂智能调度系统:自适应调度算法如何解决资源与任务匹配难题?
大数据·人工智能·汽车·制造
雨大王51235 分钟前
缩短交付周期:汽车企业如何通过计划智能体实现高效协同?
大数据·人工智能·汽车·制造
PEARL的AI指南35 分钟前
智启时代AI定制亲测:合规与私有化部署详解
人工智能
HarmonLTS36 分钟前
Python Socket网络通信详解
服务器·python·网络安全
roamingcode42 分钟前
从混沌到秩序:Git Diff 结构化报告的 Claude Code Skill 实践
人工智能·git·agent·skill·claude code·领域知识包·ai经验复用