news 2026/4/18 7:56:51

AI开发-python-langchain框架(1-6“示例学习”—— 少样本提示(Few-Shot Prompting))

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
AI开发-python-langchain框架(1-6“示例学习”—— 少样本提示(Few-Shot Prompting))

今天我们一起来看一段非常实用的LangChain 代码,它展示了如何用少样本提示(Few-Shot Prompting)的方式,让大模型更聪明、更准确地回答数学问题。我会把核心知识点拆解清楚,帮助大家理解每一步的作用和背后的原理。

什么是“少样本提示”(Few-Shot Prompting)?

  • 定义:在给大模型提问前,先提供几个输入-输出的示例,让模型“模仿”这些例子来回答新问题。
  • 作用:提升模型在特定任务上的表现,尤其适合结构化、规则明确的任务(比如数学计算、格式转换等)。
  • 类比:就像老师先讲两道例题,再让学生做第三道——学生更容易掌握规律。
知识点
说明
Few-Shot Prompting
通过少量示例引导模型行为,提升任务准确性
ChatPromptTemplate
构建多轮对话式提示的标准工具
FewShotChatMessagePromptTemplate
自动将示例列表转为对话历史
MessagesPlaceholder(本例未用但重要)
用于动态插入中间消息(如聊天历史)

看代码:

from langchain_core.prompts import ( ChatPromptTemplate, FewShotChatMessagePromptTemplate, MessagesPlaceholder, ) # 定义示例 examples = [ {"input": "2+2", "output": "4"}, {"input": "2+3", "output": "5"}, ] # 定义示例提示模板 example_prompt = ChatPromptTemplate.from_messages( [ ("human", "{input}"), ("ai", "{output}"), ] ) # 创建少样本提示模板 few_shot_prompt = FewShotChatMessagePromptTemplate( example_prompt=example_prompt, examples=examples, ) # 组装最终提示模板 final_prompt = ChatPromptTemplate.from_messages( [ ("system", "你是一位非常厉害的数学天才。"), few_shot_prompt, ("human", "{input}"), ] ) # 测试提示模板 test_input = "3+3" formatted_prompt = final_prompt.format_messages(input=test_input) print("格式化后的提示:") for msg in formatted_prompt: print(f"{msg.type}: {msg.content}") #调用大模型 from langchain_openai import ChatOpenAI from langchain_core.output_parsers import StrOutputParser import os #配置 Deepseek 密钥和模型参数 llm = ChatOpenAI( api_key=os.getenv("DEEPSEEK_API_KEY"), base_url=os.getenv("BASE_URL"), # Deepseek 的 API 基础地址 model="deepseek-v3:671b", # Deepseek 对话模型(可选:deepseek-chat-pro 等高级模型) temperature=0.7, # 温度参数(0-1,越低越稳定) max_tokens=1024 # 最大生成 tokens ) output_parser = StrOutputParser() chain = final_prompt | llm | output_parser response = chain.invoke({"input":"3的平方是多少?"}) print(response)

运行结果:

格式化后的提示: system: 你是一位非常厉害的数学天才。 human: 2+2 ai: 4 human: 2+3 ai: 5 human: 3+3 3的平方是 **9**。 计算过程: 3² = 3 × 3 = **9**
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/18 7:05:04

SpringBoot如何实现大文件上传下载?

一、技术架构设计 作为杭州自由职业者,我采用以下分层架构: 前端:Vue2-cli WebUploader二次开发(兼容IE8) 后端:SpringBoot 2.7.x(JDK 8) 存储:阿里云OSS/华为云OBS&a…

作者头像 李华
网站建设 2026/4/17 21:05:57

[特殊字符]_Web框架性能终极对决:谁才是真正的速度王者[20260126043913]

作为一名拥有10年开发经验的全栈工程师,我经历过无数Web框架的兴衰更替。从早期的jQuery时代到现在的Rust高性能框架,我见证了Web开发技术的飞速发展。今天我要分享一个让我震惊的性能对比测试,这个测试结果彻底改变了我对Web框架性能的认知。…

作者头像 李华
网站建设 2026/4/18 5:47:09

基于Java的市场公共服务设施智慧管理系统的设计与实现全方位解析:附毕设论文+源代码

1. 为什么这个毕设项目值得你 pick ? 市场公共服务设施智慧管理系统通过整合摊位、租户、租赁合同等多方面的信息,提供了一套全面的解决方案。该系统覆盖了从数据录入到统计分析等多个功能模块,并支持预警管理与安全管理等功能,确保市场的高…

作者头像 李华
网站建设 2026/4/18 6:30:07

智能助手助力软件工程毕设:8款AI应用优化论文撰写与编程复现

文章总结表格(工具排名对比) 工具名称 核心优势 aibiye 精准降AIGC率检测,适配知网/维普等平台 aicheck 专注文本AI痕迹识别,优化人类表达风格 askpaper 快速降AI痕迹,保留学术规范 秒篇 高效处理混AIGC内容&…

作者头像 李华