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

知识库别往System Prompt塞了!我用Skill Loading把3000 tokens压缩到100,省下66%成本

上篇我们诊断了System Prompt膨胀病这篇给解药。用Skill Loading机制把3000 tokens的垃圾场变成100 tokens的图书馆60行代码实现知识按需加载API成本直接砍半。Skill Loading核心机制类比图书馆借书流程图书馆不会把所有书堆你桌上而是你知道有哪些书目录需要时去借按需加载看完归还卸载释放Skill Loading就是Agent的图书馆系统Skill LibraryHarnessAgentSkill LibraryHarnessAgent后续对话不携带Python知识分析任务需要Python知识load_skill(python)读取skills/python.md返回800 tokens知识通过tool_result注入基于知识完成任务代码实现60行核心逻辑# System Prompt保持精简只告知可以加载技能SYSTEMYou are a coding assistant. You can load specialized knowledge using load_skill tool. When to use skills: - Starting a new type of task - Unfamiliar with projects tech stack - Need specific domain knowledge Available skills can be listed with list_skills.# 添加技能管理工具TOOLSBASE_TOOLS[{name:list_skills,description:List all available skills in the skill library,input_schema:{type:object,properties:{}}},{name:load_skill,description:Load a specific skill to get domain knowledge,input_schema:{type:object,properties:{skill_name:{type:string,description:Name of skill to load}},required:[skill_name]}}]# Skill管理实现deflist_available_skills():列出所有可用技能读取skills/目录skills[]forskill_fileinPath(skills/).glob(*.md):first_lineskill_file.read_text().split(\n)[0]skills.append(f-{skill_file.stem}:{first_line})return\n.join(skills)defload_skill_content(skill_name:str)-str:加载技能文档内容skill_filePath(fskills/{skill_name}.md)ifnotskill_file.exists():returnfError: Skill {skill_name} not foundreturnskill_file.read_text()# Agent循环集成defagent_loop(messages:list):whileTrue:responseclient.messages.create(modelMODEL,systemSYSTEM,messagesmessages,toolsTOOLS,max_tokens4000)messages.append({role:assistant,content:response.content})ifresponse.stop_reason!tool_use:returnresults[]forblockinresponse.content:ifblock.typetool_use:ifblock.nameload_skill:# ⭐ 按需加载技能注入上下文skill_contentload_skill_content(block.input[skill_name])results.append({type:tool_result,tool_use_id:block.id,content:f Skill Loaded \n{skill_content}})else:results.append(execute_tool(block))messages.append({role:user,content:results})运行效果代码生成场景对比传统方式System PromptSYSTEMPython规范...JavaScript规范...Go规范...# 3000 tokens用户写一个Python脚本处理CSV 模型带着3000tokens上下文推理 实际使用Python知识1000tokens 浪费2000tokens × 每轮调用Skill Loading方式SYSTEM可以加载技能...# 100 tokens用户写一个Python脚本处理CSV 模型load_skill(python)# 800 tokens模型处理任务# 精准使用800 tokens后续对话# 不携带Python知识实际对话示例User: 帮我写一个Python脚本处理CSV文件 Agent: 思考这是一个Python任务需要加载Python技能 load_skill(python) Loaded 800 chars of knowledge Agent: 根据Python技能我将使用pandas处理CSV... write_file: csv_processor.py Wrote 450 bytes User: 再用JavaScript实现同样功能 Agent: 思考需要切换技能 load_skill(javascript) Loaded 700 chars of knowledge Agent: 根据JavaScript技能我将使用csv-parse库...效果第一轮只加载Python知识第二轮只加载JavaScript知识没有知识混淆没有冗余开销给你的团队构建Skill库Skill文件格式设计# Python Development Standards ## Quick Reference - **Indent**: 4 spaces (no tabs) - **Line length**: 88 characters (Black formatter) ## Code Patterns ### Function Definition python def process_data( raw_data: dict[str, Any], options: ProcessingOptions | None None ) - ProcessedResult: Process raw data into structured format. if not raw_data: raise ValueError(raw_data cannot be empty)Common LibrariesWeb: FastAPI, Pydantic v2Data: Pandas 2.0, NumPy**设计原则** - 结构清晰模型能快速定位 - 示例驱动Show, dont tell - 长度适中500-2000 tokens ### 版本控制策略skills/├── python-v1.md # 基础版├── python-v2.md # 新增类型注解要求├── manifest.json # Skill元数据manifest.json:{“skills”: {“python”: {“current”: “python-v2”,“versions”: {“python-v2”: {“default”: true}}}}}## 避坑指南 **❌ 陷阱1Skill过大** markdown # Python Skill错误示例 - 包含Python、Django、Flask、FastAPI、NumPy、Pandas、PyTorch... - 总计10000 tokens✅ 解决方案技能拆分python-base.md # 基础语法800 tokens python-web.md # Web框架600 tokens python-ml.md # 机器学习1000 tokens❌ 陷阱2Skill冲突load_skill(python-legacy)# Python 2规范load_skill(python-modern)# Python 3规范# 冲突模型困惑✅ 解决方案命名空间# 明确指定版本skill:python version:3.11❌ 陷阱3忘记卸载前一个任务加载了Python后一个任务写JavaScript但Python知识还在上下文里干扰模型。✅ 解决方案任务边界清理defstart_new_task():# 新任务开始时只保留系统消息丢弃技能知识messages[msgformsginmessagesifmsg.get(role)system]总结知识管理的正确姿势Skill Loading解决了Agent开发的核心矛盾既要知识丰富支持各种技术栈、规范、最佳实践又要上下文精简避免知识过载导致的成本和质量问题成本对比前置加载$0.60/任务Skill Loading$0.20/任务节省66%这就像人类专家的查阅资料能力——不需要把所有知识记在脑子里而是知道去哪里找快速查阅应用到当前任务。 互动投票你的技术栈有哪些可以做成SkillA. 编程语言规范Python/JavaScript/GoB. 框架指南Django/React/VueC. 内部库文档公司私有包D. 团队编码约定Code Review标准思考题你的技术栈有哪些可以做成Skill如何设计Skill的粒度太细会导致频繁加载太粗会导致冗余如何建立Skill的版本机制

相关文章:

知识库别往System Prompt塞了!我用Skill Loading把3000 tokens压缩到100,省下66%成本

上篇我们诊断了System Prompt膨胀病,这篇给解药。 用Skill Loading机制把3000 tokens的垃圾场变成100 tokens的图书馆,60行代码实现知识按需加载,API成本直接砍半。 Skill Loading核心机制 类比:图书馆借书流程 图书馆不会把所有书…...

20轮对话后GPT开始“胡说八道“:我用Subagent分层架构让上下文永不清零

复杂任务跑20轮后,Agent开始"胡说八道"——重复已做过的操作、提出已否决的方案。 这不是模型变笨了,是上下文窗口被污染。本文用Subagent分层架构,让父Agent保持清醒,子Agent承担脏活,实现20轮对话上下文仅…...

如何分析AWR中的Top SQL_通过执行次数与物理读定位低效查询

Top SQL中Executions与Physical Reads需结合分析:执行次数多但物理读低可能暴露应用逻辑缺陷,物理读/执行>1000在OLTP中属异常,需结合执行计划、对象访问、缓存命中率等综合判断根因。怎么看 Top SQL 里的执行次数和物理读是否异常awr 报告…...

c++如何读取BMP位图文件并精确提取每个像素点的RGB值【实战】

直接用fread读BMP会错乱因像素数据BGR存储、行末补零对齐且从左下到右上排列;需跳过bfOffBits,按每行字节数对齐读取并反向索引,再手动转为RGB。为什么直接用 fread 读 BMP 文件会得到错乱的 RGB 顺序?BMP 文件头和信息头之后&…...

2026.4.5总结

今天是清明节,祭祖的日子。晚上跟妹妹和姐姐捞了不少家常。聊的是关于上一年自己做过的一些愚蠢事。读书的时候没接触过社会,导致在毕业时,吃了不少亏,也被坑了不少钱。我妹称这叫见世面。确实,刚毕业时,感…...

Python集合怎么去重_Set数据结构特性与交并差集合运算

set()去重不生效因只支持不可变类型,含列表、字典等会报TypeError;需转为可哈希形式如tuple(sorted(d.items()));自定义类须实现__hash__和__eq__;set无序,保序用dict.fromkeys();符号运算要求两边为set&am…...

CSS如何实现文字加粗而不改变宽度_利用text-shadow模拟加粗

会,text-shadow模拟加粗因软边阴影导致文字模糊,尤其小字号或Retina屏;需设blur-radius为0,用多方向1px硬边阴影(如-1px 0 0, 1px 0 0等)并启用GPU加速。text-shadow模拟加粗会导致文字模糊?会&…...

硬件发烧友玩法:多GPU分配OpenClaw调用Qwen3-32B

硬件发烧友玩法:多GPU分配OpenClaw调用Qwen3-32B 1. 为什么需要多GPU分配 作为一个长期折腾AI本地部署的硬件爱好者,我最近在尝试用OpenClaw对接Qwen3-32B模型时遇到了显存瓶颈。单卡RTX4090D的24GB显存在处理复杂任务时经常捉襟见肘,特别是…...

揭秘openGauss向量化执行引擎代价模型

揭秘openGauss向量化执行引擎代价模型openGauss的向量化执行引擎针对列存,生成执行计划后根据配置项是否开启直接决定是否将执行计划转换成向量化执行计划来执行。若向量化执行引擎在行存上执行就需要将数据转换成VectorBatch即列存的形式才可执行,这个转…...

Spring AI:Java开发者的AI应用开发利器

Spring AI:Java开发者的AI应用开发利器 一、什么是Spring AI Spring AI是一个专为AI工程应用设计的AI应用程序框架,它将AI模型的能力集成到Spring生态系统之中。作为Spring家族的新成员,Spring AI秉承了Spring的设计理念,为Java…...

C语言内存管理常见错误与防御性编程技巧

1. 指针未初始化引发的段错误1.1 结构体成员指针未初始化在C语言中,结构体内部的指针成员并不会自动分配内存。很多初学者会犯这样的错误:struct student {char *name;int score; }stu;int main() {strcpy(stu.name, "Jimy");stu.score 99;re…...

将浮点数转换成字符串时的注意事项

String s 11625907.5798 "";这串代码存入s的不是“11625907.5798”,而是“1.16259075798E7” ,用科学计数法进行存储,所以要注意字符串的长度加了2...

RoboCore SMW_SX1276M0 LoRaWAN协议栈开发指南

1. 项目概述RoboCore SMW_SX1276M0 是一款面向嵌入式物联网终端的 LoRaWAN 协议栈封装库,专为 RoboCore LoRaWAN Bee v2.0 模块设计。该模块核心采用 Semtech SX1276 射频收发器,集成高灵敏度 LoRa 调制解调器、前向纠错(FEC)、自…...

注重自己的感受 您的感受才是衡量一切的标准

人这一辈子,最拖垮你的,从来不是没钱、没机会、没天赋,是刻在骨子里的 “模糊感”。你肯定有过这种时刻:睡前刷了两小时手机,看别人搞副业月入五位数就热血沸腾,看别人裸辞环游世界就心潮澎湃,看…...

Go的unsafe.Pointer与uintptr:手动内存管理的风险与收益

Go语言以其简洁的内存管理模型著称,但标准库中的unsafe包却为开发者提供了手动操作内存的能力。unsafe.Pointer与uintptr这两个类型,允许绕过Go的类型安全检查,直接与底层内存交互。这种能力虽然强大,却也伴随着极高的风险。本文将…...

【Overview Effect】 -在抵达月球之前,让我们最后一次眺望地球

“当我们前往月球时,我们专注于探索月球,但实际上我们发现的是地球。” —— 这种视角让人们意识到,地球不仅是家园,更是一艘在寒冷宇宙中孤立无援的“救生船”。在抵达月球之前,让我们最后一次眺望地球。这张地球照片…...

OpenClaw排错大全:Phi-3-mini-128k-instruct接口连接失败7种解决方案

OpenClaw排错大全:Phi-3-mini-128k-instruct接口连接失败7种解决方案 1. 问题背景与排查思路 上周我在本地部署Phi-3-mini-128k-instruct模型时,遇到了OpenClaw连接失败的棘手问题。控制台不断报错"Model connection timeout",但…...

告别抓瞎!手把手教你用Wireshark解密TLS 1.3流量(附SSLKEYLOGFILE环境变量配置)

从密文到明文:实战解密TLS 1.3流量的完整指南 当你在调试一个API接口时,发现请求总是返回异常状态码,但查看Wireshark抓包却只能看到一堆加密的TLS 1.3数据包,这种"睁眼瞎"的感觉确实令人沮丧。TLS 1.3作为目前最安全的…...

告别龟速下载!在VMware里给UOS 20和CentOS 8配置本地yum源(保姆级图文)

企业级虚拟化环境下的高效软件管理:UOS与CentOS本地源深度配置指南 当你在企业内网或隔离开发环境中,是否经历过这样的场景:急需安装一个关键依赖包,却因为网络限制或带宽瓶颈,眼睁睁看着进度条以KB/s的速度缓慢爬行&a…...

OpenClaw开源贡献:为Qwen3.5-9B-AWQ-4bit开发社区技能

OpenClaw开源贡献:为Qwen3.5-9B-AWQ-4bit开发社区技能 1. 为什么选择为OpenClaw开发技能? 去年冬天,当我第一次在本地部署OpenClaw时,就被它的设计理念所吸引——一个真正能在个人电脑上运行的AI智能体框架。但很快我发现&#…...

[复现]神经网络(NN)+模型预测控制(MPC)算法、四旋翼无人机+非线性机器人汽车系统研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

如何高效提取Android OTA包:payload-dumper-go完整使用指南

如何高效提取Android OTA包:payload-dumper-go完整使用指南 【免费下载链接】payload-dumper-go an android OTA payload dumper written in Go 项目地址: https://gitcode.com/gh_mirrors/pa/payload-dumper-go 在Android系统开发和维护过程中,处…...

用Docker三分钟部署MetaGPT开发环境(附LLM本地化方案)

三分钟容器化部署MetaGPT全栈开发环境实战指南 容器化部署的价值与优势 在当今快速迭代的AI开发领域,环境配置一直是困扰开发者的首要难题。传统部署方式需要处理Python版本管理、依赖冲突、CUDA驱动兼容等复杂问题,而容器化技术为这一痛点提供了优雅的解…...

seo北京优化和网站内容优化有什么联系

SEO北京优化与网站内容优化的紧密联系 在当今互联网时代,对于任何企业来说,网站的优化是至关重要的一环。尤其是在竞争激烈的北京市场,SEO(搜索引擎优化)和网站内容优化之间的关系更加紧密。本文将从问题分析、原因说…...

西门子1500T插补控制从入门到精通:手把手教你配置直线与圆弧轨迹(附程序源码)

西门子1500T插补控制从入门到精通:手把手教你配置直线与圆弧轨迹(附程序源码) 在工业自动化领域,精确控制多轴协同运动一直是核心挑战。想象一下机械臂需要画一个完美的圆,或者CNC机床要切割复杂曲线——这些场景都离不…...

SAP MM新手避坑指南:手把手教你搞定UB型STO库存调拨(从ME21N到MIGO全流程)

SAP MM新手避坑指南:手把手教你搞定UB型STO库存调拨(从ME21N到MIGO全流程) 刚接触SAP MM模块的新手,面对库存转储订单(STO)这个看似简单实则暗藏玄机的功能时,往往会在UB型订单的创建和操作过程…...

开发环境神器:OpenClaw+Qwen3-14B镜像自动化调试与日志分析

开发环境神器:OpenClawQwen3-14B镜像自动化调试与日志分析 1. 为什么开发者需要自动化调试助手 作为一名全栈开发者,我每天要面对各种复杂的调试场景:前端页面渲染异常、后端接口返回500错误、数据库查询性能低下...传统的调试方式需要手动…...

从零到一:基于XXL-JOB构建企业级分布式任务调度中心实战指南

1. 为什么选择XXL-JOB作为分布式任务调度方案 第一次接触分布式任务调度时,我像大多数开发者一样面临选择困难。市面上既有成熟的商业产品,也有各种开源方案。经过多个项目的实战验证,XXL-JOB以其轻量级架构和易用性脱颖而出。这个由国内开发…...

CVPR2025新思路:把对抗扰动本身当成‘训练数据’,聊聊PSP-UAP背后的设计哲学

CVPR2025新思路:对抗扰动作为训练数据的革命性设计哲学 对抗样本研究领域正在经历一场范式转变——从单纯制造攻击工具到重新思考扰动本身的语义价值。PSP-UAP(Pseudo-Semantic Prior Universal Adversarial Perturbation)的突破性在于&#…...

从零到一:STM32 SPWM逆变器设计全流程解析

从零到一:STM32 SPWM逆变器设计全流程解析 在新能源和电力电子领域,逆变器作为直流转交流的关键设备,其设计能力已成为工程师的核心竞争力之一。而基于STM32的SPWM逆变器设计,因其高性价比和灵活可控的特点,正成为工业…...