3-输出解析器outputParsers

输出解析器

  • 通过输出解析器,可以控制响应的结构和格式
  • 没用的情况
使用输出解析器
  • 创建一个 output-parsers.js
js 复制代码
import { StringOutputParser } from "@langchain/core/output_parsers"; // 输出解析器
import { ChatPromptTemplate } from "@langchain/core/prompts";
import { ChatOpenAI } from "@langchain/openai";
import * as dotenv from "dotenv";

// 加载环境变量
dotenv.config();

// 初始化模型
const model = new ChatOpenAI({
  model: process.env.AI_MODEL || "deepseek-chat", // 增加默认值防止未定义
  apiKey: process.env.DEEPSEEK_API_KEY,
  configuration: {
    baseURL: process.env.BASE_URL,
  },
  temperature: 0.7,
  maxTokens: 1024,
  verbose: true,
});

async function run() {
  try {
    // 格式必须是: ["角色类型", "模板内容"]
    // 常用角色: "system" (系统设定), "user" (用户), "human" (同user)
    const prompt = ChatPromptTemplate.fromMessages([
      // 第一条消息:设定系统角色
      ["system", "也是一个幽默的段子手。"],
      // 第二条消息:用户的输入
      ["user", "说一个关于 {input} 的笑话。"],
    ]);

    // 创建输出解析器:将模型输出解析为JSON
    const parser = new StringOutputParser();

    // 创建链:将提示词模板连接到模型 -> **通过pipe(管道)连接到解析器**
    const chain = prompt.pipe(model).pipe(parser);

    // 调用链并等待结果 (必须使用 await)
    const response = await chain.invoke({
      input: "摔跤",
    });
    console.log(response);
  } catch (error) {
    console.error("运行出错:", error);
  }
}

// 执行主函数
run();
  • 另一种输出解释器
js 复制代码
import {
  CommaSeparatedListOutputParser,
  StringOutputParser,
} from "@langchain/core/output_parsers"; // 输出解析器
import { ChatPromptTemplate } from "@langchain/core/prompts";
import { ChatOpenAI } from "@langchain/openai";
import * as dotenv from "dotenv";

// 加载环境变量
dotenv.config();

// 初始化模型
const model = new ChatOpenAI({
  model: process.env.AI_MODEL || "deepseek-chat", // 增加默认值防止未定义
  apiKey: process.env.DEEPSEEK_API_KEY,
  configuration: {
    baseURL: process.env.BASE_URL,
  },
  temperature: 0.7,
  maxTokens: 1024,
  verbose: true,
});

async function callCommaSeparatedListOutputParser() {
  const prompt = ChatPromptTemplate.fromTemplate(`
        你是一个段子手,请根据 {word} 生成一个笑话
    `);
  const outputParser = new CommaSeparatedListOutputParser();
  const chain = prompt.pipe(model).pipe(outputParser);
  return await chain.invoke({ word: "摔跤" });
}

const response = await callCommaSeparatedListOutputParser();
console.log(response);

结构化输出解析器(Structured Output Parser)

  • 根据去提取信息,按照对应的js对象格式输出
js 复制代码
import {
  //   CommaSeparatedListOutputParser,
  StructuredOutputParser,
} from "@langchain/core/output_parsers"; // 输出解析器
import { ChatPromptTemplate } from "@langchain/core/prompts";
import { ChatOpenAI } from "@langchain/openai";
import * as dotenv from "dotenv";

// 加载环境变量
dotenv.config();

// 初始化模型
const model = new ChatOpenAI({
  model: process.env.AI_MODEL || "deepseek-chat", // 增加默认值防止未定义
  apiKey: process.env.DEEPSEEK_API_KEY,
  configuration: {
    baseURL: process.env.BASE_URL,
  },
  temperature: 0.7,
  maxTokens: 1024,
  verbose: true,
});

async function callStructuredOutputParser() {
  const prompt = ChatPromptTemplate.fromTemplate(`
        提取用户给的信息,按照要求的JSON格式输出
        Instructions: {format_instructions}
        用户输入: {phrase}
    `);
  const outputParser = StructuredOutputParser.fromNamesAndDescriptions({
    name: "这个人的名字",
    age: "这个人的年龄",
  });
  const chain = prompt.pipe(model).pipe(outputParser);
  return await chain.invoke({
    phrase: "Max is 30 years old",
    format_instructions: outputParser.getFormatInstructions(),
  });
}

const response = await callStructuredOutputParser();
使用更高级的方式(推荐)
  • 安装:pnpm add zod
js 复制代码
import {
  StructuredOutputParser,
} from "@langchain/core/output_parsers"; // 输出解析器
import { ChatPromptTemplate } from "@langchain/core/prompts";
import { ChatOpenAI } from "@langchain/openai";
import * as dotenv from "dotenv";
import { z } from "zod";

// 加载环境变量
dotenv.config();

// 初始化模型
const model = new ChatOpenAI({
  model: process.env.AI_MODEL || "deepseek-chat", // 增加默认值防止未定义
  apiKey: process.env.DEEPSEEK_API_KEY,
  configuration: {
    baseURL: process.env.BASE_URL,
  },
  temperature: 0.7,
  maxTokens: 1024,
  verbose: true,
});

async function callZodOutputParser() {
  const prompt = ChatPromptTemplate.fromTemplate(`
        提取用户给的信息,按照要求的JSON格式输出
        Instructions: {format_instructions}
        用户输入: {phrase}
    `);

  const outputParser = StructuredOutputParser.fromZodSchema(
    z.object({
      recipe: z.string().describe("食材的名字"),
      ingredient: z.array(z.string()).describe("食材的各种原料"),
    }),
  );

  const chain = prompt.pipe(model).pipe(outputParser);

  return await chain.invoke({
    phrase: "这是西红柿炒蛋,里面有西红柿、蛋、盐、油、葱等",
    format_instructions: outputParser.getFormatInstructions(), //格式化指令
  });
}

const response = await callZodOutputParser();
console.log(response);

后面学习分片查询

相关推荐
用户4130622582937 分钟前
给AI回答加引用角标citation:RAG前端实现
人工智能
米小虾1 小时前
WAIC 2026 倒计时30天:300+ AI 产品全球首发,今年看点全解析
人工智能
码上天下1 小时前
多模态Agent上传图片:前端压缩格式与预览实战
人工智能
姗姗来迟了1 小时前
Vue3封装可复用AI对话组件:一次抽象复盘
人工智能
怕浪猫2 小时前
哪些软件对 Chrome DevTools Protocol 频繁使用
人工智能·架构·前端框架
leo在掘金3 小时前
从DeepSeek 510亿融资到GitHub 33K Star开源项目:这周的技术生态发生了什么?
人工智能
小姜前线技术4 小时前
AI流式渲染打字机效果抖动?节流方案踩坑实录
人工智能
用户018349301694 小时前
AI对话状态管理:useReducer还是XState
人工智能
先锋部队4 小时前
给AI对话加「停止生成」按钮:abort SSE实战
人工智能