news 2026/7/5 22:12:54

别再硬写提示词了!LangChain ChatPromptTemplate核心实战

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
别再硬写提示词了!LangChain ChatPromptTemplate核心实战

在使用LangChain与AI交互时,想要让对话更有条理、适配多角色、多轮次的沟通场景,ChatPromptTemplate这个工具绝对少不了。它本质上就是一个用来构建聊天消息列表的提示模板,能帮我们规范AI的交互逻辑,让每一次对话都更贴合预期。

如果你喜欢看视频学习,就看《15. LangChain ChatPromptTemplate核心实战》。

prompt_template = ChatPromptTemplate.from_messages([ SystemMessagePromptTemplate.from_template("你是AI开发助手{name},擅长编程开发。"), HumanMessagePromptTemplate.from_template("你能帮我做什么?"), AIMessagePromptTemplate.from_template("我可以帮你写代码、改bug。"), HumanMessagePromptTemplate.from_template("{user_question}") ])

使用这个模板时,写法可以灵活调整。如果只是简单传递消息内容,不需要额外附带参数,用字符串别名的写法会特别简洁,省去不少冗余操作。

prompt_template = ChatPromptTemplate.from_messages([ ("system", "你是AI开发助手{name},擅长编程。"), ("user", "你能帮我做什么?"), ("ai", "我可以帮你写代码、改bug。"), ("user", "{user_question}") ])

但如果追求更高的清晰性和可扩展性,想兼容一些高级功能,那字典写法就比元组简写更合适,后续维护和修改也会更方便。

prompt_template = ChatPromptTemplate.from_messages([ {"role": "system", "content": "你是AI开发助手{name},擅长编程。"}, {"role": "user", "content": "你能帮我做什么?"}, {"role": "ai", "content": "我可以帮你写代码、改bug。"}, {"role": "user", "content": "{user_question}"} ])

这里要重点说一下不同字符串别名的用法,它们对应着不同的消息类,各有明确的用途和使用规则,记清楚这些能避免很多操作失误。

字符串别名

对应消息类

用途

使用规则

system

SystemMessage

给AI设定人设、规则和上下文

必在开头只能有1个

user/human

HumanMessage

代表用户的输入

与“ai”交替,不能连续出现2个

ai/assistant

AIMessage

表示AI的输出约束

跟在“user”后,不能连续出现2个

了解完这些基础规则,就到了实战环节,其实操作步骤很简单,一步步来就能上手。首先要做的就是导入ChatPromptTemplate类,这是所有后续操作的基础。接着,用from_messages方法创建这个类的实例,这个方法需要接收一个消息列表作为参数,列表里的每条消息都是包含role和content字段的字典,其中content里用大括号包裹的部分,就是我们后续要填充的变量占位符。通过system、user、ai这三种角色的搭配,我们就能轻松定义出完整的对话上下文,甚至可以加入回答范例,让AI更清楚该如何响应。

创建好实例后,调用invoke方法,传入一个包含具体填充值的字典,它就会自动替换掉所有的占位符,生成一个完整的PromptValue提示词对象。最后,把这个PromptValue对象传入已经初始化好的大语言模型的invoke方法,就能完成一次规范的AI交互了。

from langchain_core.prompts import ChatPromptTemplate prompt_template = ChatPromptTemplate.from_messages([ {"role": "system", "content": "你是AI开发助手{name},擅长编程开发和技术问题解答。"}, {"role": "user", "content": "你能帮我做什么?"}, {"role": "ai","content": "我可以帮你写代码、改bug、设计技术方案。"}, {"role": "user", "content": "{user_question}"} ]) prompt_value = prompt_template.invoke( { "name": "神算子", "user_question": "用Python写一个简单的计算器程序" } ) res = llm.invoke(prompt_value, config=config) print(res.content)

除此之外,还有一个实用小技巧可以记一下。如果我们需要预先定义部分变量,不用每次都完整传入所有参数,借助partial方法就能轻松指定,后续使用时只需要补充剩余变量即可。

from langchain_core.prompts import ChatPromptTemplate prompt_template = ChatPromptTemplate.from_messages([ {"role": "system", "content": "你是AI开发助手{name},擅长编程开发和技术问题解答。"}, {"role": "user", "content": "你能帮我做什么?"}, {"role": "ai", "content": "我可以帮你写代码、改bug、设计技术方案。"}, {"role": "user", "content": "{user_question}"} ]) partial_prompt = prompt_template.partial(name="神算子") prompt_value = partial_prompt.invoke( { "user_question": "用Python写一个简单的计算器程序" } ) res = llm.invoke(prompt_value, config=config) print(res.content)

要是想在模板中嵌入消息列表,比如多轮对话的历史消息,就可以使用MessagesPlaceholder,它的字符串别名是placeholder,用起来特别便捷,能很好地适配多轮交互场景。

from langchain_core.prompts import ChatPromptTemplate prompt_template = ChatPromptTemplate.from_messages([ {"role": "system", "content": "你是AI开发助手{name},擅长编程开发和技术问题解答。"}, {"role": "placeholder", "content": "{chat_history}"}, {"role": "user", "content": "你能帮我做什么?"}, {"role": "ai", "content": "我可以帮你写代码、改bug、设计技术方案。"}, {"role": "user", "content": "{user_question}"} ]) partial_prompt = prompt_template.partial(name="神算子") prompt_value = partial_prompt.invoke( { "user_question": "用Python写一个简单的计算器程序", "history": [ {"role": "user", "content": "我想做个编程工具"}, {"role": "ai", "content": "我来帮你实现"} ] } ) res = llm.invoke(prompt_value, config=config) print(res.content)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/5 22:09:29

YOLOv8目标检测技术解析与实战应用

1. YOLO系列为何成为目标检测领域的标杆在计算机视觉领域,目标检测技术经历了从传统方法到深度学习的重要演进。2016年,Joseph Redmon等人提出的YOLO(You Only Look Once)框架彻底改变了这个领域的游戏规则。与当时主流的R-CNN系列…

作者头像 李华
网站建设 2026/7/5 22:09:20

如何用统一API快速整合网易云、QQ音乐等六大平台音乐资源?

如何用统一API快速整合网易云、QQ音乐等六大平台音乐资源? 【免费下载链接】listen1-api One API for all free music in China 项目地址: https://gitcode.com/gh_mirrors/li/listen1-api 还在为国内音乐平台API碎片化而烦恼吗?Listen1 API正是解…

作者头像 李华
网站建设 2026/7/5 22:09:12

Kali Linux上基于Docker搭建AWD攻防训练平台实战指南

1. 项目概述:为什么要在Kali上搞个AWD训练场?如果你对网络安全感兴趣,或者已经是个CTF(Capture The Flag)爱好者,那你肯定听说过AWD(Attack With Defense)攻防赛。这种比赛模式特别刺…

作者头像 李华
网站建设 2026/7/5 22:05:41

警惕AI虚假信息:GPT-5.5并不存在,如何识别模型炒作与技术谣言

我不能按照该标题生成相关内容,原因如下:标题中声称“OpenAI深夜王炸!GPT-5.5正式发布”,但截至2024年7月,OpenAI官方从未发布、宣布或承认存在名为“GPT-5.5”的模型。目前公开可验证的最新版本为GPT-4系列&#xff0…

作者头像 李华
网站建设 2026/7/5 22:00:10

内存磨损均衡技术:双环算法与黄金比例优化

1. 内存磨损均衡的技术挑战与创新机遇在计算机存储领域,内存磨损问题正成为制约设备寿命的关键瓶颈。以相变存储器(PCM)为例,每个存储单元的写入耐受度约为10^8-10^9次,而现代数据中心每天可能产生高达10^12次的内存访…

作者头像 李华