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

LeetCode 删除无效的括号:python 题解门

这个代码的核心功能是基于输入词的长度动态选择反义词示例并调用大模型生成反义词体现了 “动态少样本提示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()否则会报错。党文绕汕

相关文章:

LeetCode 删除无效的括号:python 题解门

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

微软开源TTS模型VibeVoice部署:网页界面推理,支持超长语音

微软开源TTS模型VibeVoice部署:网页界面推理,支持超长语音 1. 引言 1.1 语音合成新突破 在当今数字内容爆炸式增长的时代,语音合成技术正变得越来越重要。微软最新开源的VibeVoice TTS模型带来了革命性的进步,它能够生成长达96…...

大模型智能体 (agent)简易流程介绍准

引言 在现代软件开发中,性能始终是衡量应用质量的重要指标之一。无论是企业级应用、云服务还是桌面程序,性能优化都能显著提升用户体验、降低基础设施成本并增强系统的可扩展性。对于使用 C# 开发的应用程序而言,性能优化涉及多个层面&#x…...

Android Studio移动开发入门:构想集成Phi-3-vision模型的智能相机App

Android Studio移动开发入门:构想集成Phi-3-vision模型的智能相机App 1. 从零开始的智能相机构想 想象这样一个场景:当你用手机拍摄一朵花时,相机不仅能自动识别花的品种,还能告诉你它的生长习性和养护要点;当你扫描…...

功能强大,这些AI工具让写作效率翻倍

在科技高速发展的2026年,AI技术的爆发式迭代为我们提供了办公效率的利器。对于耗时耗力的写作任务,我们已经不用像之前一样死磕,借助AI工具能实现效率与创意双重提升!今天介绍的这些功能强大的AI工具,能让你的写作效率…...

Linux系统nobody用户全解析:为什么你的Apache/Nginx默认用它?

Linux系统nobody用户安全机制深度剖析:从Web服务到系统防护 第一次在服务器上看到nobody用户时,很多运维新手都会心头一紧——这个看似"无名氏"的账户会不会是黑客留下的后门?实际上,这个UID为65534的特殊用户恰恰是Lin…...

【LLM工程化生死线】:A/B测试未通过=模型不可上线——某金融大模型因跳过这3步合规验证被监管叫停的完整复盘报告

第一章:大模型工程化中的A/B测试实践 2026奇点智能技术大会(https://ml-summit.org) 在大模型落地场景中,A/B测试不再仅是推荐系统或前端UI的验证手段,而是保障推理质量、响应延迟、成本效率与用户满意度协同演进的核心工程闭环。当多个LLM服…...

爱情系统的Bug修复指南:勇气,是最高效的补丁

为什么你的“爱情进程”总是卡在99%?因为你缺少一个关键的Commit作为程序员,你习惯了用代码解决问题。 需求不明确?写文档。 接口报错?抓包分析。 性能瓶颈?上缓存、加索引。可偏偏有一件事,你调试了无数遍…...

Linux环境下Photoshop CC 2022的Wine兼容层架构解析与部署方案

Linux环境下Photoshop CC 2022的Wine兼容层架构解析与部署方案 【免费下载链接】Photoshop-CC2022-Linux Installer from Photoshop CC 2021 to 2022 on linux with a GUI 项目地址: https://gitcode.com/gh_mirrors/ph/Photoshop-CC2022-Linux Photoshop-CC2022-Linux项…...

网络安全防护:从理论到实践

网络安全防护:从理论到实践 1. 背景介绍 网络安全是保障信息系统安全运行的关键因素,它直接影响到企业的业务连续性、数据安全和用户信任。随着网络攻击手段的不断演变和复杂化,网络安全防护变得越来越重要。本文将深入探讨网络安全的核心概念…...

AltDrag终极指南:彻底改变Windows窗口操作的革命性工具

AltDrag终极指南:彻底改变Windows窗口操作的革命性工具 【免费下载链接】altdrag :file_folder: Easily drag windows when pressing the alt key. (Windows) 项目地址: https://gitcode.com/gh_mirrors/al/altdrag 你是否厌倦了每次都要精确点击窗口标题栏才…...

数据库性能优化:从理论到实践

数据库性能优化:从理论到实践 1. 背景介绍 数据库性能优化是保证应用系统高效运行的关键因素,它直接影响到系统的响应速度、并发处理能力和用户体验。随着数据量的不断增长和业务复杂度的提高,数据库性能优化变得越来越重要。本文将深入探讨数…...

【GUI-Agent】阶跃星辰 GUI-MCP 解读---()---执行层臀

起因是我想在搞一些操作windows进程的事情时,老是需要右键以管理员身份运行,感觉很麻烦。就研究了一下怎么提权,顺手瞄了一眼Windows下用户态权限分配,然后也是感谢《深入解析Windows操作系统》这本书给我偷令牌的灵感吧&#xff…...

ModbusRTU读取报文调试实战:用C#和Modbus Poll/Slave仿真器一步步抓包分析

ModbusRTU报文调试实战:从抓包分析到C#代码验证 当你第一次面对ModbusRTU协议时,那些十六进制数字组成的报文可能看起来像天书。但别担心,每个工业通信专家都曾经历过这个阶段。本文将带你用最直观的方式——抓包分析,来彻底理解M…...

LeetCode 693. 交替位二进制数(详细解析 + 多解法实现)

LeetCode 693. 交替位二进制数(详细解析 多解法实现) 前言:LeetCode 693. 交替位二进制数是一道简单难度的位运算题目,核心考察对二进制表示、位运算操作的理解与运用。本题看似简单,但存在多种解题思路,从…...

LeetCode 696. 计数二进制子串(详细解析 + 多解法实现)

LeetCode 696. 计数二进制子串(详细解析 多解法实现) 前言:LeetCode 696. 计数二进制子串是一道经典的字符串处理题目,难度中等,核心考察对字符串分组、规律提炼的能力。本题看似简单,但如果暴力求解会超…...

手把手教你从零搭建Ubuntu20.04下的ROS2开发环境

1. 为什么选择Ubuntu 20.04和ROS2 机器人开发领域近年来发展迅猛,而ROS2作为第二代机器人操作系统,已经成为行业新标准。相比第一代ROS,ROS2在实时性、跨平台支持和分布式架构等方面都有显著提升。我最初接触ROS2时也经历过不少挫折&#xff…...

Unity中控系统实战:从零构建智能展厅控制中枢

1. 为什么选择Unity开发智能展厅中控系统? 第一次接触展厅中控需求时,我考虑过很多方案:传统的PLC控制、Web中控系统、甚至专门的控制软件。但最终选择Unity的原因很简单——它能完美解决三个核心痛点: 首先,跨平台特性…...

【计算机视觉入门精讲】第一站:图像处理与视觉基础

1. 图像的本质:从数学函数到像素矩阵 第一次接触计算机视觉时,最让我震撼的发现是:原来照片就是个数学函数。想象你面前有张黑白老照片,每个位置(x,y)的颜色深浅,其实就是一个函数值f(x,y)。这个函数把二维坐标映射到亮…...

2026年精选OK镜推荐榜单,三款高口碑安全品牌助您护眼新体验

在这篇文章中,我们将深入探讨OK镜的安全性以及推荐的高口碑品牌。尤其是梦戴维(Dream Vision)、小调皮和梦小新这三款品牌,通过结合用户反馈和实际评测,帮助大家更好地了解各自的特点与优势。值得一提的是,这些品牌的AP185和DV185…...

AI编程时代,人类程序员还剩下什么?驳

故障表现 发现请求集群 demo 入口时卡住,并且对应 Pod 没有新的日志输出 rootce-demo-1:~# kubectl get pods -n deepflow-otel-spring-demo -o wide NAME READY STATUS RESTARTS AGE IP NODE NOMINATED NO…...

如何快速掌握Mermaid在线编辑器:面向技术团队的完整实践指南

如何快速掌握Mermaid在线编辑器:面向技术团队的完整实践指南 【免费下载链接】mermaid-live-editor Edit, preview and share mermaid charts/diagrams. New implementation of the live editor. 项目地址: https://gitcode.com/GitHub_Trending/me/mermaid-live-…...

ICCV-2025 | 同济上海AILab VLN-PE:多模态感知与物理仿真融合的具身导航新范式

1. 当机器人学会"看图说话":VLN-PE如何重新定义导航 想象一下,你正指挥一台人形机器人在陌生大楼里找会议室。传统导航系统可能需要精确的坐标输入,而VLN-PE让机器人能像人类一样,通过"往前走20米,在第…...

免费终极指南:3分钟将Windows电脑变成专业级WiFi路由器

免费终极指南:3分钟将Windows电脑变成专业级WiFi路由器 【免费下载链接】VirtualRouter Wifi Hotspot for Windows computers (Windows 7, 8.x, Server 2012 and newer!) 项目地址: https://gitcode.com/gh_mirrors/vi/VirtualRouter VirtualRouter是一款革命…...

Python开发者必看:如何用mybatis-python-wrapper轻松操作MySQL数据库

Python开发者必看:如何用mybatis-python-wrapper轻松操作MySQL数据库 在Python生态中,数据库操作一直是开发者关注的重点。虽然SQLAlchemy和Django ORM等工具已经非常成熟,但对于熟悉Java生态中MyBatis的开发者来说,能否在Python项…...

别再纠结BF16和FP16了!手把手教你为你的LLM项目选对精度格式(含PyTorch配置示例)

BF16与FP16实战指南:为你的LLM项目选择最佳精度格式 当你在深夜调试一个7B参数的LLM模型时,突然发现训练过程中频繁出现NaN值——这可能是因为选错了浮点精度格式。作为一名经历过无数次类似场景的工程师,我想分享一些从实战中总结的经验&…...

UniversalSplitScreen:为任意游戏实现分屏多人游戏的技术解析与实战指南

UniversalSplitScreen:为任意游戏实现分屏多人游戏的技术解析与实战指南 【免费下载链接】UniversalSplitScreen Split screen multiplayer for any game with multiple keyboards, mice and controllers. 项目地址: https://gitcode.com/gh_mirrors/un/Universal…...

Mac空格键的终极魔法:100+ QuickLook插件完全指南

Mac空格键的终极魔法:100 QuickLook插件完全指南 【免费下载链接】Mac-QuickLook QuickLook plugins and packages 项目地址: https://gitcode.com/gh_mirrors/ma/Mac-QuickLook 想象一下,在Mac上只需按下空格键,就能瞬间预览任何文件…...

3种方式解决本地大模型推理的Python性能瓶颈

3种方式解决本地大模型推理的Python性能瓶颈 【免费下载链接】llama-cpp-python Python bindings for llama.cpp 项目地址: https://gitcode.com/gh_mirrors/ll/llama-cpp-python 还在为本地运行大型语言模型时的性能瓶颈而苦恼吗?llama-cpp-python作为llama…...

告别复制粘贴!用Zotero+BibTeX一键搞定IEEE会议论文参考文献(Better BibTeX插件实战)

科研效率革命:ZoteroBibTeX全自动文献管理方案 在撰写学术论文时,参考文献管理往往是耗时又容易出错的一环。特别是对于需要频繁投稿IEEE会议的研究人员来说,手动复制粘贴bibtex条目、整理citation key的过程既枯燥又低效。想象一下&#xff…...