news 2026/5/12 14:45:24

【Nanobot项目解析-提示词构建器的工作原理】

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
【Nanobot项目解析-提示词构建器的工作原理】

提示词构建器的工作原理

Nanobot的提示词构建器通过ContextBuilder类实现,负责组装完整的提示词上下文,为LLM提供结构化的指令和信息。

核心工作流程

1. 初始化

def__init__(self,workspace:Path):self.workspace=workspace self.memory=MemoryStore(workspace)self.skills=SkillsLoader(workspace)
  • 接收工作区路径
  • 初始化记忆存储和技能加载器

2. 系统提示词构建

defbuild_system_prompt(self,skill_names:list[str]|None=None)->str:# 组装各个部分parts=[]# 核心身份parts.append(self._get_identity())# 引导文件bootstrap=self._load_bootstrap_files()ifbootstrap:parts.append(bootstrap)# 记忆上下文memory=self.memory.get_memory_context()ifmemory:parts.append(f"# Memory\n\n{memory}")# 技能# 1. 始终加载的技能always_skills=self.skills.get_always_skills()ifalways_skills:always_content=self.skills.load_skills_for_context(always_skills)ifalways_content:parts.append(f"# Active Skills\n\n{always_content}")# 2. 可用技能:只显示摘要skills_summary=self.skills.build_skills_summary()ifskills_summary:parts.append(f"# Skills\n...{skills_summary}")return"\n\n---\n\n".join(parts)

3. 完整消息构建

defbuild_messages(self,history:list[dict[str,Any]],current_message:str,skill_names:list[str]|None=None,media:list[str]|None=None)->list[dict[str,Any]]:messages=[]# 系统提示词system_prompt=self.build_system_prompt(skill_names)messages.append({"role":"system","content":system_prompt})# 历史消息messages.extend(history)# 当前用户消息(支持图片)user_content=self._build_user_content(current_message,media)messages.append({"role":"user","content":user_content})returnmessages

关键组件

1. 核心身份信息

  • 包含当前时间、工作区路径、可用工具等基本信息
  • 定义了助手的基本行为准则

2. 引导文件

  • 加载AGENTS.md,SOUL.md,USER.md,TOOLS.md,IDENTITY.md等文件
  • 这些文件包含了更详细的指令和配置

3. 记忆系统

  • memory/MEMORY.md和每日笔记中加载记忆
  • 为助手提供长期记忆能力

4. 技能系统

  • 始终加载的技能:直接包含完整内容
  • 可用技能:只显示摘要,需要时通过read_file工具加载
  • 技能摘要包含技能名称、描述和可用性

5. 媒体支持

  • 支持图片附件,通过 base64 编码嵌入到消息中

运行机制

  1. 初始化阶段:创建 ContextBuilder 实例,准备工作区和依赖组件
  2. 提示词构建
    • 调用build_system_prompt()生成系统提示词
    • 系统提示词包含身份、引导文件、记忆和技能信息
  3. 消息组装
    • 调用build_messages()组装完整消息列表
    • 消息列表按顺序包含:系统提示词 → 历史消息 → 当前用户消息
  4. 交互过程
    • LLM 基于完整消息列表生成响应
    • 若需要执行工具,添加工具执行结果
    • 添加助手响应消息,完成一轮交互

特点与优势

  1. 模块化设计:各个组件(身份、引导文件、记忆、技能)独立管理
  2. 渐进式技能加载:常用技能直接加载,其他技能只显示摘要
  3. 多媒体支持:可处理图片等媒体文件
  4. 结构化提示词:通过清晰的标题和分段,提高 LLM 理解效率
  5. 上下文感知:包含时间、工作区等上下文信息,使助手更加智能

总结

Nanobot 的提示词构建器是一个精心设计的系统,通过以下步骤工作:

  1. 收集信息:从工作区、记忆、技能系统中收集相关信息
  2. 结构化组织:将信息组织成清晰的结构,包括身份、引导文件、记忆和技能
  3. 组装消息:按正确的顺序组装系统提示词、历史消息和当前用户消息
  4. 支持交互:提供添加工具结果和助手消息的方法,支持完整的交互流程

这种设计使得 Nanobot 能够为 LLM 提供丰富、结构化的上下文信息,从而生成更加准确和相关的响应。同时,通过渐进式技能加载等策略,它也能够在保持提示词简洁的同时,提供对大量技能的访问能力。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/29 20:44:48

Qwen3-ASR-1.7B vs 商业API:开源语音识别模型对比测评

Qwen3-ASR-1.7B vs 商业API:开源语音识别模型对比测评 你是否曾为项目寻找一个靠谱的语音识别方案,却在开源模型和商业API之间反复纠结?一边是免费开源但担心效果不佳,另一边是效果稳定但成本高昂、数据隐私存疑。这种选择困境&a…

作者头像 李华
网站建设 2026/5/12 11:01:38

零基础入门SeqGPT-560M:5分钟搞定文本分类与信息抽取

零基础入门SeqGPT-560M:5分钟搞定文本分类与信息抽取 你是否遇到过这样的场景: 刚收到一批用户评论,需要快速判断是好评还是差评; 手头有上百条新闻稿,得在半小时内标出哪些属于“政策解读”、哪些是“市场动态”&…

作者头像 李华
网站建设 2026/5/9 3:37:10

Z-Image极速引擎实测:用Jimeng AI Studio轻松创作高清影像

Z-Image极速引擎实测:用Jimeng AI Studio轻松创作高清影像 1. 为什么这次实测让我重新相信“快”和“美”可以兼得 你有没有过这样的体验: 输入一段描述,盯着进度条数秒——结果画面一出来,细节糊成一片,边缘发虚&am…

作者头像 李华
网站建设 2026/5/2 2:07:53

保姆级教程:用LoRA训练助手为Stable Diffusion生成完美tag集

保姆级教程:用LoRA训练助手为Stable Diffusion生成完美tag集 在AI绘画模型训练中,高质量的英文标签(tag)是决定LoRA或Dreambooth效果的关键一环。但对大多数中文用户来说,手动撰写规范、全面、权重合理的英文tag既耗时…

作者头像 李华
网站建设 2026/5/10 5:58:38

两相交错并联同步整流双向Buck - Boost变换器仿真那些事儿

两相交错并联同步整流双向Buck Boost变换器仿真 所有开关管均可实现ZVs软开关 Buck模式 输入:200-360VDC 额定280VDC 输出:140VDC 10A 开关频率:10kHz Boost模式: 输入:120-160VDC 额定140VDC 输出:280VDC…

作者头像 李华
网站建设 2026/5/5 7:25:28

图片旋转判断模型实测:自动校正效果对比

图片旋转判断模型实测:自动校正效果对比 你有没有遇到过这样的烦恼?从手机相册里导出的照片,在电脑上查看时莫名其妙地歪了;或者从网上下载的图片,方向总是不对,需要手动旋转才能正常显示。手动一张张调整…

作者头像 李华