news 2026/4/16 8:38:11

【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/11 12:35:58

Qwen3-ASR-1.7B vs 0.6B:语音识别模型选择指南

Qwen3-ASR-1.7B vs 0.6B:语音识别模型选择指南 你是否遇到过这样的场景:会议录音转文字错漏百出,方言客服录音识别成乱码,嘈杂环境下的采访音频几乎无法识别?语音识别不是“能用就行”,而是“必须准、必须稳…

作者头像 李华
网站建设 2026/4/16 5:38:56

不用写代码!用Qwen-Image搭建个人AI图片生成平台

不用写代码!用Qwen-Image搭建个人AI图片生成平台 想拥有自己的AI图片生成服务却不懂编程?现在只需几分钟,无需任何代码基础,就能搭建专属的AI艺术创作平台! 你是否曾经想过拥有一个属于自己的AI图片生成器,…

作者头像 李华
网站建设 2026/4/16 7:13:23

造相-Z-Image 实战:电商产品图一键生成全流程

造相-Z-Image 实战:电商产品图一键生成全流程 在电商运营节奏越来越快的今天,一张高质量主图往往决定用户是否愿意点击进入详情页;而一款能稳定输出写实质感、适配中文描述、无需联网依赖的本地化工具,正成为中小团队内容生产的刚…

作者头像 李华
网站建设 2026/4/16 7:19:15

好写作AI:凌晨四点的“赛博导师”,揭秘重度用户的“人机共生”模式

当你的同学还在纠结论文第二段,高频用户已经用AI完成初稿、查重降重、并生成了答辩预演PPT——他们到底开了什么挂?凌晨四点,某大学宿舍楼的网络流量图上出现了一个规律性高峰:57台设备同时访问好写作AI服务器。这不是黑客攻击&am…

作者头像 李华
网站建设 2026/4/16 7:14:37

Qwen2.5-VL视觉定位模型:无需标注数据的实用指南

Qwen2.5-VL视觉定位模型:无需标注数据的实用指南 你是否曾想过,让AI像人一样“看图说话”,并精准指出图中的目标?比如,你上传一张家庭聚会的照片,告诉AI“找到穿红色衣服的小孩”,它就能立刻用…

作者头像 李华