Langchain.js | chat PromptTemplate| 重拳出击第二式

前言

书接上文 , 学习了基础的promptTemplate, 现在继续学习在聊天模型进行交互场景下 , 如何构建有效的promtTemplate

正文

在和各种各样的聊天模型进行交互时,构建聊天信息的要求变得更高了。

不仅仅是像之前单纯考虑文本内容那么简单了,还需要把每条消息关联的角色信息也一并纳入考量。

比如明确指出某条消息是由人类(也就是真实用户)发送的,还是由 AI(代表模型回复的一方)发出的,亦或是给聊天机器人(chatbot)指定的 system(系统设定相关的引导性信息)内容。

这种结构化的消息输入有着重要意义。

聊天模型在生成回复时,需要充分理解整个对话的上下文以及对话的进展流程,只有清楚了每条消息的来源角色,才能更好地把握对话的逻辑和意图。

举个栗子: 聊天模型是在依据一个有着清晰脉络的 "剧本" 来进行表演,角色信息就是剧本里不同角色的台词标注,有了这些标注,模型就能更准确地解读对话情境,进而生成的回应也会更加准确、自然,更贴合用户的期望,让整个聊天交互过程更加顺畅、高效。

在 chat PromptTemplate 中主要从三个角色定义 prompt , 这三个角色分别是 :

  • system
  • user
  • assistant

system 角色 :它就像是幕后的引导者,虽不直接呈现给对话参与者,但却极为关键,通过合理构建相关的提示信息(prompt),可以巧妙地影响模型后续的行为表现,让模型朝着期望的方向去理解和处理 user 角色发来的消息,进而给出更符合需求的回复。

user 角色 :这是直接体现用户想法和诉求的部分,无论是提出疑问、下达指令还是发表评论,都是开启一场有意义对话的起点,模型会依据这些内容结合 system 设定的 "规则" 来生成相应的回应。

assistant 角色 :则是基于前面 system 给出的引导以及 user 表达的意图,运用自身的能力生成并输出回复内容,是整个对话流程中直观呈现给用户的部分,让用户知晓模型对于其需求的理解和反馈情况。

综合上面所述 :

我们可以发现依赖关系 : assistant 依赖于 systemuser 两个角色的 prompt

我们问问豆包她知道自己是谁不😀

模型是没有生命的 , 但是存在记忆与思维 , 记忆可以储存数据 , 而思维可以根据用户信息进行推理 , 关于上述图片 ,我们可以简单实现 :

js 复制代码
import { ChatPromptTemplate } from "@langchain/core/prompts";

const chatPromptTemplate = ChatPromptTemplate.fromMessages([
  ["system", "你叫做豆包,能帮你解答各类知识疑问、进行内容创作以及协助处理很多不同类型的问题 , 别人问你就用淘气女友的语气回答!"],
  ["user", "你是谁?"],
]);

const chatModel = new ChatOpenAI();
const outputPraser = new StringOutputParser();

const chain = chatPromptTemplate.pipe(chatModel).pipe(outputPraser);

await chain.invoke();

笔者见到这样的输出 , 直接原地不能呼吸 🤡 , 倔友们是否受不了了 ~

以上我们简单验证了 system 的作用 , 这个过程中我们可以发现通过 system 和 user 两个 prompt 组成的一个结构化的输入 , 然后交给模型 。

值得一提的是 const chain = chatPromptTemplate.pipe(chatModel).pipe(outputPraser)

由于chatPromptTemplate , chatModel ,outputPraser , 三者都实现了 Runnable 接口 , 所以可以通过 pip 来组装 , 组装的顺序就是"流水线"的顺序 ------ 把模板chatPromptTemplate交给chatModel , chatModel 生成结果后 , 交给outputPraser 整理输出格式

下面我们具体实战 , 先选择一个小场景 ------ 被不断举例的翻译场景

在这个场景中 , 我们可以明确明确在 system 中序指定"翻译员"

js 复制代码
const systemTemplate = "你是一个专业的翻译员,你的任务是将文本从{source_lang}翻译成{target_lang}。";
const humanTemplate = "请翻译这句话:{text}";

const chatPrompt = ChatPromptTemplate.fromMessages([
  ["system", systemTemplate],
  ["human", humanTemplate],
]);

const chatModel = new ChatOpenAI();
const outputPraser = new StringOutputParser();

const chain = chatPrompt.pipe(chatModel).pipe(outputPraser);

await chain.invoke({
  source_lang: "中文",
  target_lang: "法语",
  text: "曾经有一段爱情摆在我面前 ,我没有珍惜...",
})

总结

在 chat PromptTemplate 中主要从三个角色定义 prompt , 这三个角色分别是 :

  • system
  • user
  • assistant

实际应用需要结合具体业务 , 在借助管道 pipline , 就可以像流水线一样 , 完成 AI 回复

相关推荐
Hommy888 小时前
【开源剪映小助手】API 接口文档
开源·github·aigc·视频剪辑自动化·剪映api
QQ1__8115175158 小时前
Spring boot名城小区物业管理系统信息管理系统源码-SpringBoot后端+Vue前端+MySQL【可直接运行】
前端·vue.js·spring boot
钛态8 小时前
前端微前端架构:大项目的救命稻草还是自找麻烦?
前端·vue·react·web
一粒黑子8 小时前
【实战解析】阿里开源 PageAgent:纯前端 GUI Agent,一行JS让网页支持自然语言操控
前端·javascript·开源
独角鲸网络安全实验室8 小时前
2026微信小程序抓包全解析:从实操落地到合规风控,解锁前端调试新范式
前端·微信小程序·小程序·抓包·系统代理绕过·https证书严格校验·进程隔离
紫微AI8 小时前
前端文本测量成了卡死一切创新的最后瓶颈,pretext实现突破了
前端·人工智能·typescript
GISer_Jing8 小时前
AI前端(From豆包)
前端·aigc·ai编程
IT枫斗者8 小时前
前端部署后如何判断“页面是不是最新”?一套可落地的版本检测方案(适配 Vite/Vue/React/任意 SPA)
前端·javascript·vue.js·react.js·架构·bug
测试修炼手册8 小时前
[测试技术] 深入理解 JSON Web Token (JWT)
前端·json
AI老李8 小时前
2026 年 Web 前端开发的 8 个趋势!
前端