当前位置: 首页 > article >正文

“你用AI,那我也会用AI,我还要你干什么?”罕

这个代码的核心功能是基于输入词的长度动态选择反义词示例并调用大模型生成反义词体现了 “动态少样本提示Dynamic Few-Shot Prompting” 与 “上下文长度感知的示例选择” 的能力。from langchain.prompts import FewShotPromptTemplate, PromptTemplatefrom langchain.prompts.example_selector import LengthBasedExampleSelectorfrom langchain_core.output_parsers import StrOutputParserfrom langchain_openai import ChatOpenAIimport osfrom dotenv import load_dotenv# 定义反义词任务的示例数据集few-shot examples# 每个示例包含一个输入词input和对应的反义词outputexamples [{input: 开心, output: 伤心},{input: 高, output: 矮},{input: 精力充沛, output: 没精打采},{input: 粗, output: 细},]# 定义单个示例的格式模板# 使用 {input} 和 {output} 作为占位符用于后续填充具体值example_prompt PromptTemplate(input_variables[input, output], # 声明模板中使用的变量名templateInput: {input}\nOutput: {output}, # 示例的文本格式)# 创建一个基于长度的示例选择器LengthBasedExampleSelector# 作用根据输入提示的总长度动态选择最合适的示例数量避免超出模型上下文限制example_selector LengthBasedExampleSelector(examplesexamples, # 提供所有候选示例example_promptexample_prompt, # 用于格式化每个示例的模板max_length25, # 设定整个 prompt含前缀、示例、后缀的最大 token 长度此处为字符数近似# 注意LengthBasedExampleSelector 默认使用 len(text) 计算长度非精确 token 数适用于简单场景)# 构建动态少样本提示模板FewShotPromptTemplate# 它会根据输入内容的长度自动从 examples 中选择合适数量的示例插入到 prompt 中dynamic_prompt FewShotPromptTemplate(example_selectorexample_selector, # 使用上面定义的动态选择器而非固定示例列表example_promptexample_prompt, # 单个示例的格式prefix给出每个输入的反义词, # 提示的开头部分任务指令suffixInput: {adjective}\nOutput:, # 提示的结尾部分包含待预测的输入占位符input_variables[adjective], # 声明最终用户输入的变量名与 suffix 中的 {adjective} 对应)# 测试 1输入较短应选择多个示例 print(【测试1】输入较短选择多个示例)print(dynamic_prompt.format(adjectivebig))print(------------)# 测试 2输入很长应只选择少量或一个示例以控制总长度 long_string big and huge and massive and large and gigantic and tall and much much much much much bigger than everything elseprint(【测试2】输入很长仅选择一个示例)print(dynamic_prompt.format(adjectivelong_string))print(------------)# 测试 3动态添加新示例 # 向示例选择器中新增一个示例胖 - 瘦new_example {input: 胖, output: 瘦}dynamic_prompt.example_selector.add_example(new_example)print(【测试3】添加新示例后查询热情)print(dynamic_prompt.format(adjective热情))print(------------)# 配置并调用 DeepSeek 大语言模型 llm ChatOpenAI(api_keyos.getenv(DEEPSEEK_API_KEY),base_urlos.getenv(DEEP_URL), # Deepseek 的 API 基础地址modeldeepseek-v3:671b, # Deepseek 对话模型可选deepseek-chat-pro 等高级模型temperature0.7, # 温度参数0-1越低越稳定max_tokens1024 # 最大生成 tokens)# 创建字符串输出解析器用于将模型返回的 AIMessage 转换为纯文本output_parser StrOutputParser()# 构建处理链Chainprompt → LLM → output parser# 使用 LangChain 的管道操作符 | 连接各组件chain dynamic_prompt | llm | output_parser# 调用链传入输入变量 {adjective: 热情}# 注意chain.invoke() 内部已包含 llm 调用和 output_parser 解析无需再手动调用 output_parsermessage chain.invoke({adjective: 热情})# ?? 注意上一行 chain.invoke() 已经返回了字符串因为最后是 StrOutputParser# 所以下面这行是多余的甚至会导致错误因为 message 已是 str不能再次 invoke# result output_parser.invoke(message) # ? 错误message 是 str不是 AIMessage# 正确做法直接使用 message 作为结果result messageprint(###############)print(【模型输出】)print(result)输出结果123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051【测试1】输入较短选择多个示例给出每个输入的反义词Input: 开心Output: 伤心Input: 高Output: 矮Input: 精力充沛Output: 没精打采Input: 粗Output: 细Input: bigOutput:------------【测试2】输入很长仅选择一个示例给出每个输入的反义词Input: 开心Output: 伤心Input: big and huge and massive and large and gigantic and tall and much much much much much bigger than everything elseOutput:------------【测试3】添加新示例后查询热情给出每个输入的反义词Input: 开心Output: 伤心Input: 高Output: 矮Input: 精力充沛Output: 没精打采Input: 粗Output: 细Input: 胖Output: 瘦Input: 热情Output:------------###############【模型输出】冷淡核心要点总结这段代码是基于 LangChain 框架对接 DeepSeek 大模型实现「动态少样本Few-Shot反义词生成」的完整案例核心解决「固定示例易超出模型上下文长度」的问题通过动态示例选择器适配不同长度输入同时结合 LangChain 链式调用简化模型调用流程先明确整体定位再拆解核心重点一、整体流程概览核心逻辑链代码遵循 LangChain 「示例准备 → 动态提示构建 → 模型调用 → 结果解析」的少样本学习经典流程整体可概括为1. 定义反义词任务的固定示例数据集为模型提供参考案例2. 配置基于长度的示例选择器根据输入文本长度动态筛选示例数量3. 构建动态少样本提示模板自动适配输入长度生成合规 Prompt4. 初始化 DeepSeek 模型客户端配置核心调用参数5. 构建「提示模板 → 大模型 → 输出解析」的链式调用流程6. 调用链条完成反义词生成并输出纯文本结果二、核心重点拆解必掌握1. 少样本提示Few-Shot Prompt核心组件这是实现「模型参考示例生成结果」的基础也是 LangChain 提示工程的核心用法- 示例数据集examples以键值对形式存储「输入-输出」示例为模型提供任务参考如开心→伤心- 单示例模板example_prompt定义单个示例的文本格式Input/Output 固定样式统一示例展示形式- 动态少样本模板FewShotPromptTemplate整合示例选择器、单示例模板、前缀/后缀生成最终发给模型的完整 Prompt- prefix任务指令给出每个输入的反义词明确模型要执行的任务- suffix待填充的用户输入占位符承接动态输入内容。2. 动态示例选择器LengthBasedExampleSelector这是代码的核心亮点解决「固定示例数量易超上下文长度」的问题核心作用根据输入文本的长度自动计算并选择合适数量的示例输入越长选的示例越少避免 Prompt 总长度超出模型上下文限制关键参数- examples候选示例列表- example_prompt示例格式化模板用于计算单示例长度- max_lengthPrompt 允许的最大长度此处为字符数近似值。3. LangChain 链式调用| 操作符简化多组件协作流程是 LangChain 核心设计理念- 链条构成dynamic_prompt生成 Prompt | llm调用模型 | output_parser解析结果- 核心优势无需手动分步调用先格式化 Prompt、再调用模型、最后解析结果一行代码完成全流程- 调用方式chain.invoke({adjective: 热情}) 传入输入变量直接返回解析后的纯文本结果。4. 输出解析器StrOutputParser解决「模型返回 AIMessage 对象→提取纯文本」的问题核心作用将 LangChain 模型返回的 AIMessage 类型含 content/metadata 等字段转换为纯字符串简化结果使用关键注意点链式调用中已包含解析步骤无需手动再次调用 output_parser.invoke()否则会报错。笛装逗又

相关文章:

“你用AI,那我也会用AI,我还要你干什么?”罕

这个代码的核心功能是:基于输入词的长度动态选择反义词示例,并调用大模型生成反义词,体现了 “动态少样本提示(Dynamic Few-Shot Prompting)” 与 “上下文长度感知的示例选择” 的能力。 from langchain.prompts impo…...

Qwen3-ForcedAligner-0.6B多语言支持实测:52种语言自动检测与对齐能力

Qwen3-ForcedAligner-0.6B多语言支持实测:52种语言自动检测与对齐能力 1. 引言:音文对齐的实用价值 你有没有遇到过这样的场景:手里有一段音频和对应的文字稿,需要精确知道每个词在音频中的具体时间位置?传统方法需要…...

告别在线转换!用PowerShell+FFmpeg批量把FLAC无损转成ALAC(附完整脚本)

打造高效音频工作流:PowerShellFFmpeg批量转换FLAC到ALAC全攻略 每次整理音乐库时,最头疼的就是格式兼容性问题。上周我帮朋友迁移他的2000多首FLAC音乐到苹果设备,原本打算用在线转换工具,结果光是上传就花了整整一天——这还不算…...

会计岗位学习数据分析的价值分析

一、会计岗位数据分析能力需求上升的背景数字化转型浪潮席卷各行各业,传统会计职能从核算记录向决策支持转变。企业财务数据量激增,手工处理效率低下,需要借助数据分析工具挖掘数据价值。国际财务报告准则(IFRS)和税务…...

Qwen3智能字幕对齐系统开发环境搭建:基于IDEA的Java SDK调试指南

Qwen3智能字幕对齐系统开发环境搭建:基于IDEA的Java SDK调试指南 如果你是一名Java开发者,最近想尝试接入Qwen3智能字幕对齐系统的能力,比如为视频自动生成精准的字幕时间轴,那么这篇文章就是为你准备的。今天,我们不…...

终极Windows系统优化指南:Dism++让你告别卡顿的10个技巧

终极Windows系统优化指南:Dism让你告别卡顿的10个技巧 【免费下载链接】Dism-Multi-language Dism Multi-language Support & BUG Report 项目地址: https://gitcode.com/gh_mirrors/di/Dism-Multi-language Dism是一款功能强大的Windows系统优化和维护工…...

G-Helper:重构华硕设备性能管理的轻量级解决方案 | 玩家与商务人士必备工具

G-Helper:重构华硕设备性能管理的轻量级解决方案 | 玩家与商务人士必备工具 【免费下载链接】g-helper Lightweight, open-source control tool for ASUS laptops and ROG Ally. Manage performance modes, fans, GPU, battery, and RGB lighting across Zephyrus, …...

FastAPI 2.0异步流式响应实战配置:7个必踩坑点+3个性能翻倍技巧,工程师连夜重写API的真正原因

第一章:FastAPI 2.0异步AI流式响应的核心机制与演进本质FastAPI 2.0 将原生异步支持从底层框架能力升维为语义化流式契约,其核心在于将 StreamingResponse 与 async generator 深度耦合,并通过 ASGI 3.0 的 send 协议实现零拷贝分块传输。相比…...

Fish-Speech-1.5在JavaWeb项目中的集成实践

Fish-Speech-1.5在JavaWeb项目中的集成实践 1. 引言 想象一下,你的JavaWeb应用能够像真人一样说话——电商平台的商品介绍不再冰冷生硬,在线教育的内容讲解充满情感波动,智能客服的回应自然流畅。这就是Fish-Speech-1.5带来的变革。 Fish-…...

终极Windows系统维护指南:使用Dism++轻松管理你的操作系统

终极Windows系统维护指南:使用Dism轻松管理你的操作系统 【免费下载链接】Dism-Multi-language Dism Multi-language Support & BUG Report 项目地址: https://gitcode.com/gh_mirrors/di/Dism-Multi-language Dism是一款强大的Windows系统维护工具&…...

使用VSCode高效开发OFA-VE应用

使用VSCode高效开发OFA-VE应用 1. 引言 如果你正在开发OFA-VE视觉蕴含分析应用,那么选择合适的开发工具能让你事半功倍。VSCode作为目前最受欢迎的代码编辑器之一,凭借其丰富的插件生态和强大的功能,能够显著提升你的开发效率。 无论你是刚…...

WuliArt Qwen-Image Turbo惊艳效果:1024×1024输出中火焰/水流/烟雾动态形态自然度

WuliArt Qwen-Image Turbo惊艳效果:10241024输出中火焰/水流/烟雾动态形态自然度 你有没有想过,用AI生成一张火焰燃烧、水流奔腾或者烟雾缭绕的图片,结果却得到一团僵硬、模糊、毫无生气的色块?这几乎是所有文生图模型在处理动态…...

Qwen-Image-2512-Pixel-Art-LoRA 在嵌入式设备上的应用展望:边缘计算与像素艺术

Qwen-Image-2512-Pixel-Art-LoRA 在嵌入式设备上的应用展望:边缘计算与像素艺术 1. 从云端到指尖:像素艺术的边缘化想象 最近在玩一些像素风的独立游戏,看着那些由简单色块构成的精致画面,我就在想,要是能随时随地、…...

你的热电偶读数总跳?可能是50/60Hz工频干扰!STM32驱动MAX31856的滤波配置避坑指南

热电偶读数跳变?50/60Hz工频干扰的精准诊断与MAX31856滤波实战 工业现场的温度测量工程师们,是否经常遇到这样的困扰:明明硬件连接正确,STM32与MAX31856的驱动代码也按手册编写,但热电偶读数却像心电图一样上下跳动&am…...

Qwen3.5-35B-AWQ-4bit开源可部署:ARM架构服务器适配可行性验证报告

Qwen3.5-35B-AWQ-4bit开源可部署:ARM架构服务器适配可行性验证报告 1. 模型概述 Qwen3.5-35B-A3B-AWQ-4bit是一款面向视觉多模态理解的开源量化模型,特别针对ARM架构服务器进行了优化适配。该模型在保持高性能的同时,通过4bit量化技术显著降…...

百度网盘提取码智能获取工具:如何3秒内快速解锁加密资源?

百度网盘提取码智能获取工具:如何3秒内快速解锁加密资源? 【免费下载链接】baidupankey 项目地址: https://gitcode.com/gh_mirrors/ba/baidupankey 还在为百度网盘加密资源而烦恼吗?每次遇到需要提取码的分享链接,你都要…...

告别串口调试!用ESP32-C3内置USB-JTAG在VSCode中实现高效开发

告别串口调试!用ESP32-C3内置USB-JTAG在VSCode中实现高效开发 嵌入式开发中,调试环节往往占据大量时间成本。传统串口调试需要反复插拔线缆、配置波特率,而逻辑分析仪又存在价格门槛。ESP32-C3芯片内置的USB-JTAG功能,正在改变这…...

Qwen3-ForcedAligner-0.6B与Python爬虫结合:自动采集语音数据并对齐

Qwen3-ForcedAligner-0.6B与Python爬虫结合:自动采集语音数据并对齐 1. 引言 语音数据处理一直是人工智能领域的热门话题,但很多开发者在实际项目中都会遇到这样的问题:如何快速获取大量的语音数据?如何让文本和语音精确对齐&am…...

Qwen3-ForcedAligner-0.6B效果展示:WAV/MP3混合输入下98.2%字级对齐准确率

Qwen3-ForcedAligner-0.6B效果展示:WAV/MP3混合输入下98.2%字级对齐准确率 1. 惊艳效果开场:语音识别的精准新标杆 想象一下这样的场景:一段包含中文、英文混合的会议录音,背景还有轻微的键盘敲击声。传统的语音识别工具可能只能…...

DeepSeek-R1-Distill-Qwen-1.5B案例展示:数学推理能力超越GPT-4o

DeepSeek-R1-Distill-Qwen-1.5B案例展示:数学推理能力超越GPT-4o 1. 模型核心能力解析 1.1 技术架构亮点 DeepSeek-R1-Distill-Qwen-1.5B采用知识蒸馏技术,将Qwen2.5-Math-1.5B基础模型与R1架构优势相结合。其核心创新点包括: 参数压缩技…...

vLLM-v0.17.1环境快速部署:Windows系统下Python与CUDA配置详解

vLLM-v0.17.1环境快速部署:Windows系统下Python与CUDA配置详解 1. 前言:为什么选择vLLM? 如果你正在Windows系统上探索大语言模型的高效推理方案,vLLM绝对值得关注。这个由加州大学伯克利分校团队开发的开源项目,以其…...

Jimeng AI Studio(Z-Image Edition)与Python爬虫数据结合:自动化图像生成实战

Jimeng AI Studio(Z-Image Edition)与Python爬虫数据结合:自动化图像生成实战 1. 引言 你有没有遇到过这样的情况:每天需要为大量新闻资讯、产品信息或社交媒体内容配图,但手动设计耗时耗力,外包成本又太…...

AI超清画质增强实战:低分辨率图片修复,让模糊变清晰

AI超清画质增强实战:低分辨率图片修复,让模糊变清晰 1. 技术背景与核心价值 1.1 为什么需要超分辨率技术 在数字图像处理领域,我们经常遇到这样的困扰:珍贵的家庭老照片因年代久远变得模糊不清;从网络下载的图片分辨…...

Qwen3.5-2B效果展示:低参数模型在中文长文本摘要与英文翻译中的准确表现

Qwen3.5-2B效果展示:低参数模型在中文长文本摘要与英文翻译中的准确表现 1. 轻量化多模态模型概述 Qwen3.5-2B是Qwen3.5系列中的轻量化版本,仅有20亿参数规模,专为低功耗、低门槛部署场景设计。这款模型特别适合在端侧设备和边缘计算环境中…...

intv_ai_mk11行业应用:跨境电商团队用intv_ai_mk11批量生成多语种商品描述

intv_ai_mk11行业应用:跨境电商团队用intv_ai_mk11批量生成多语种商品描述 1. 跨境电商的多语言挑战 跨境电商团队每天面临一个共同难题:如何高效地为同一商品生成不同语言版本的描述。传统方法要么依赖人工翻译(成本高、速度慢&#xff09…...

AI智能二维码工坊视频流识别:摄像头实时扫码部署教程

AI智能二维码工坊视频流识别:摄像头实时扫码部署教程 1. 项目简介 AI智能二维码工坊是一个全能型二维码处理工具,基于Python QRCode生成库与OpenCV视觉识别库构建。与依赖庞大深度学习模型的项目不同,本项目采用纯算法逻辑实现,…...

CADSpotting+: Enhancing Panoptic Symbol Recognition in Large-Scale CAD Drawings with Dynamic Point S

1. CADSpotting:大规模CAD图纸中的全景符号识别新突破 想象一下你手里有一张复杂的建筑CAD图纸,上面密密麻麻布满了各种符号——门窗、墙体、家具、电气设备……传统方法要识别这些符号就像在迷宫里找路,而CADSpotting的出现,就像…...

一键部署你的私人知识大脑:MindMap + Docker Compose 极速搭建指南

1. 为什么你需要一个私人知识大脑? 不知道你有没有这样的经历:电脑里存了几百个PDF文档,收藏夹里塞满了网页链接,手机相册里全是截图的知识点,但要用的时候死活找不到。更糟心的是,有些在线笔记工具突然收费…...

第零章(K8s启航):最新Ubuntu25 安装最新K8S (断电重启、断电重置)超详细步骤,安装不好你来打我~

Ubuntu安装K8S1. 服务器初始化(所有节点) vim /etc/hosts127.0.0.1 localhost # 127.0.1.1 yww# The following lines are desirable for IPv6 capable hosts ::1 ip6-localhost ip6-loopback fe00::0 ip6-localnet ff00::0 ip6-mcastprefix ff02::1…...

MVT协议深度解析:从Protobuf编码到GISBox实战,看它如何碾压传统栅格瓦片

MVT协议技术内幕:从二进制编码到百万级数据渲染实战 当我们打开手机地图App,双指放大查看小区楼栋轮廓时,很少有人会思考这流畅体验背后的技术革命。传统栅格瓦片就像打印在纸上的地图,放大后必然出现马赛克;而MVT协议…...