当前位置: 首页 > 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…...

瑞芯微RK3506开发板实战指南:Qt应用开发环境配置与调试技巧

1. 认识RK3506开发板与Qt开发环境 RK3506是瑞芯微推出的一款高性能嵌入式处理器,采用四核Cortex-A35架构,主频可达1.5GHz,支持多种显示接口和丰富的外设资源。这款开发板特别适合需要图形界面交互的嵌入式应用场景,比如工业控制、…...

打造你的专属数字伙伴:BongoCat虚拟桌宠完全指南 [特殊字符]

打造你的专属数字伙伴:BongoCat虚拟桌宠完全指南 🐱 【免费下载链接】BongoCat 🐱 跨平台互动桌宠 BongoCat,为桌面增添乐趣! 项目地址: https://gitcode.com/gh_mirrors/bong/BongoCat 你是否曾幻想过在单调的…...

Windows媒体播放终极解码方案:LAV Filters完整指南

Windows媒体播放终极解码方案:LAV Filters完整指南 【免费下载链接】LAVFilters LAV Filters - Open-Source DirectShow Media Splitter and Decoders 项目地址: https://gitcode.com/gh_mirrors/la/LAVFilters 如果你在Windows上观看视频时经常遇到格式不支…...

3步掌握Blender 3MF插件:轻松实现3D打印文件无缝导入导出

3步掌握Blender 3MF插件:轻松实现3D打印文件无缝导入导出 【免费下载链接】Blender3mfFormat Blender add-on to import/export 3MF files 项目地址: https://gitcode.com/gh_mirrors/bl/Blender3mfFormat 想要在Blender中直接处理3D打印文件吗?B…...

AI量化投资实战指南:从零开始构建强化学习市场中性策略

AI量化投资实战指南:从零开始构建强化学习市场中性策略 【免费下载链接】qlib Qlib is an AI-oriented Quant investment platform that aims to use AI tech to empower Quant Research, from exploring ideas to implementing productions. Qlib supports diverse…...

从无人机防抖到股票预测:聊聊卡尔曼滤波在你身边的那些‘隐藏’应用

从无人机防抖到股票预测:卡尔曼滤波如何悄悄优化你的日常生活 想象一下,你正在用手机拍摄一段奔跑中的宠物视频,画面却出奇地稳定;或者驾驶着搭载自动驾驶辅助系统的车辆,它总能精准预判前车距离。这些看似"智能&…...

6、深入解析transforms.RandomAffine():参数详解与实战应用

1. 什么是RandomAffine变换? RandomAffine是PyTorch中torchvision.transforms模块提供的一个非常实用的图像增强方法。简单来说,它能够对图像进行一系列随机的仿射变换操作。你可能要问:什么是仿射变换?其实它就是我们日常生活中常…...

别光记公式!用Python+OpenCV手把手带你标定相机内参外参(附完整代码)

别光记公式!用PythonOpenCV手把手带你标定相机内参外参(附完整代码) 在计算机视觉项目中,相机标定是构建三维感知系统的第一步。很多开发者能背诵内参矩阵的数学形式,却对如何用代码实际获取这些参数一头雾水。本文将用…...

从原生UI到插件化框架:RAGENativeUI在GTA模组开发中的架构重构

从原生UI到插件化框架:RAGENativeUI在GTA模组开发中的架构重构 【免费下载链接】RAGENativeUI 项目地址: https://gitcode.com/gh_mirrors/ra/RAGENativeUI 在Grand Theft Auto V模组开发领域,界面系统长期面临着原生集成度低、性能开销大、开发…...

Unity托管堆内存优化实战:如何避免频繁GC引发的性能卡顿

1. 为什么你的Unity游戏会卡顿?GC是罪魁祸首 刚做完的Unity游戏明明跑得好好的,一到真机上就出现迷之卡顿?特别是场景切换或者特效爆发时,画面突然卡住0.5秒?这很可能就是垃圾回收(GC)在搞鬼。…...

突破单机限制:PlugY重塑暗黑破坏神2游戏体验的五大维度升级

突破单机限制:PlugY重塑暗黑破坏神2游戏体验的五大维度升级 【免费下载链接】PlugY PlugY, The Survival Kit - Plug-in for Diablo II Lord of Destruction 项目地址: https://gitcode.com/gh_mirrors/pl/PlugY 一、单机玩家的困境与破局之道 在暗黑破坏神…...

Phi-4-mini-reasoning实战案例:为数学竞赛平台提供实时解题思路生成API

Phi-4-mini-reasoning实战案例:为数学竞赛平台提供实时解题思路生成API 1. 项目背景与需求 数学竞赛平台"MathMaster"面临一个关键挑战:如何为参赛学生提供实时、准确的解题思路指导。传统人工解答方式存在响应慢、成本高、覆盖范围有限等问…...

LIN矩阵解析实战:从Excel到位定义的自动化转换工具与应用

1. LIN矩阵解析的工程痛点与自动化需求 在汽车电子开发中,LIN总线通信设计总是绕不开矩阵表的处理。每次拿到客户提供的Excel格式矩阵表时,工程师们都会面临三大灵魂拷问:如何快速理解上百个信号定义?如何避免手动解析时的位运算错…...

避坑指南:Ubuntu 18.04下编译Android 15源码的常见错误及解决方案

Ubuntu 18.04下编译Android 15源码的避坑实战手册 作为一名长期深耕Android系统开发的工程师,我深知在Ubuntu环境下编译AOSP源码的痛点和挑战。特别是当Android版本更新到15.0时,编译环境的兼容性问题、驱动文件的获取方式、以及各种隐藏的配置陷阱&…...

STM32定时器编码器模式实战:5分钟搞定电机转速与转向测量(附常见波形问题排查)

STM32定时器编码器模式实战:5分钟搞定电机转速与转向测量(附常见波形问题排查) 在机器人控制和自动化项目中,电机转速和转向的精确测量往往是系统闭环控制的基础。传统软件计数方式不仅占用CPU资源,还容易因中断延迟导…...

Palworld存档工具终极指南:掌握游戏数据编辑的专业方法

Palworld存档工具终极指南:掌握游戏数据编辑的专业方法 【免费下载链接】palworld-save-tools Tools for converting Palworld .sav files to JSON and back 项目地址: https://gitcode.com/gh_mirrors/pa/palworld-save-tools 你是否曾想过深入Palworld游戏…...

3步解锁旧内核:KernelSU在Linux 4.14+设备上的完整适配指南

3步解锁旧内核:KernelSU在Linux 4.14设备上的完整适配指南 【免费下载链接】KernelSU A Kernel based root solution for Android 项目地址: https://gitcode.com/GitHub_Trending/ke/KernelSU 你是否还在为Android设备的内核版本过低而无法使用KernelSU感到…...

VutronMusic:重新定义跨平台音乐体验的全能播放器

VutronMusic:重新定义跨平台音乐体验的全能播放器 【免费下载链接】VutronMusic 高颜值的第三方网易云播放器;支持流媒体音乐,如navidrome、jellyfin、emby;支持本地音乐播放、离线歌单、逐字歌词、桌面歌词、Touch Bar歌词、Mac状…...

深入TC3xx安全机制:从WDT密码访问到Endinit保护,如何构建防误写屏障?

TC3xx芯片安全架构深度解析:Endinit机制与汽车电子功能安全实践 在汽车电子系统设计中,功能安全从来不是可选项而是必选项。随着ADAS和自动驾驶技术的快速发展,ECU的复杂性和安全性要求呈指数级增长。TC3xx系列芯片作为汽车电子领域的核心处…...

HSTracker终极指南:如何快速上手macOS炉石套牌追踪器

HSTracker终极指南:如何快速上手macOS炉石套牌追踪器 【免费下载链接】HSTracker A deck tracker and deck manager for Hearthstone on macOS 项目地址: https://gitcode.com/gh_mirrors/hs/HSTracker HSTracker是一款专为macOS玩家打造的炉石传说套牌追踪与…...

Adrenaline终极指南:解锁PSP模拟器的完整潜力

Adrenaline终极指南:解锁PSP模拟器的完整潜力 【免费下载链接】Adrenaline Custom Firmware 6.61 Adrenaline for the PSP Emulator 项目地址: https://gitcode.com/gh_mirrors/adr/Adrenaline 你是否曾为PSP模拟器的功能限制而烦恼?想要在PS Vit…...

BepInEx框架架构深度解析:Unity游戏插件开发核心技术揭秘

BepInEx框架架构深度解析:Unity游戏插件开发核心技术揭秘 【免费下载链接】BepInEx Unity / XNA game patcher and plugin framework 项目地址: https://gitcode.com/GitHub_Trending/be/BepInEx BepInEx(Bepis Injector Extensible)作…...

SecGPT-14B模型调优指南:降低OpenClaw安全任务Token消耗

SecGPT-14B模型调优指南:降低OpenClaw安全任务Token消耗 1. 为什么需要关注Token消耗问题 去年冬天,当我第一次用OpenClaw对接SecGPT-14B执行安全日志分析时,被惊人的Token消耗吓了一跳——一个简单的500行日志分析任务竟然消耗了近3万Toke…...

避坑指南:OpenClaw云端一键部署的5个关键配置,90%的人都踩过前3个

OpenClaw作为目前最火的开源AI智能体框架,凭借低代码、多模型兼容、全渠道对接(飞书/钉钉/Telegram等)的特性,已经成为个人开发者、中小团队搭建专属AI员工的首选方案。 各大云厂商也纷纷推出了OpenClaw一键部署镜像,号…...

从零开始:如何用AutoModelForCausalLM.from_pretrained加载自定义模型(含本地模型和私有模型)

从零开始:AutoModelForCausalLM.from_pretrained加载自定义模型实战指南 当你第一次尝试加载一个自定义的因果语言模型时,可能会被各种参数和配置选项搞得晕头转向。作为一位经历过无数次模型加载失败的开发者,我深知那种看着报错信息却不知…...

如何通过TPFanCtrl2实现ThinkPad风扇智能控制:3步配置终极静音方案

如何通过TPFanCtrl2实现ThinkPad风扇智能控制:3步配置终极静音方案 【免费下载链接】TPFanCtrl2 ThinkPad Fan Control 2 (Dual Fan) for Windows 10 and 11 项目地址: https://gitcode.com/gh_mirrors/tp/TPFanCtrl2 TPFanCtrl2是一款专为ThinkPad笔记本设计…...

猫抓资源嗅探工具高效解决方案:从问题诊断到高级配置

猫抓资源嗅探工具高效解决方案:从问题诊断到高级配置 【免费下载链接】cat-catch 猫抓 浏览器资源嗅探扩展 / cat-catch Browser Resource Sniffing Extension 项目地址: https://gitcode.com/GitHub_Trending/ca/cat-catch 你是否遇到过这样的情况&#xff…...

四足机器人步态调参实战:如何用Walk These Ways控制器实现楼梯穿越与抗干扰行走

四足机器人步态调参实战:Walk These Ways控制器在复杂地形中的应用技巧 当Unitree Go1机器人第一次站在楼梯前时,开发者们面临着一个经典困境——如何让这台在平地上表现优异的机器跨越这道障碍。传统解决方案往往需要重新训练模型或调整底层算法&#…...

RePKG:5分钟掌握Wallpaper Engine资源提取与转换的终极指南

RePKG:5分钟掌握Wallpaper Engine资源提取与转换的终极指南 【免费下载链接】repkg Wallpaper engine PKG extractor/TEX to image converter 项目地址: https://gitcode.com/gh_mirrors/re/repkg RePKG是一款专为Wallpaper Engine用户设计的开源工具&#x…...