news 2026/6/9 17:28:04

【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/6/9 18:40:02

无需联网!Moondream2本地化图片问答系统搭建教程

无需联网!Moondream2本地化图片问答系统搭建教程 你是否曾想过,让电脑像人一样“看懂”图片,并回答你关于图片的任何问题?比如,上传一张商品图,让它自动生成详细的英文描述用于AI绘画;或者上传…

作者头像 李华
网站建设 2026/6/9 18:37:52

YOLOv12目标检测5分钟快速上手:图片视频双模式本地识别

YOLOv12目标检测5分钟快速上手:图片视频双模式本地识别 1. 为什么你值得花5分钟试试这个工具 你有没有遇到过这些场景: 想快速知道一张监控截图里有没有人、车或异常物品,但不想上传到云端——怕隐私泄露做教学演示需要实时分析一段课堂录像&…

作者头像 李华
网站建设 2026/6/9 18:40:17

学术导航仪已就位!书匠策AI:本科论文写作的“六维超能引擎”

对于本科生而言,论文写作往往是一场“知识迷雾中的探险”——选题撞车、逻辑混乱、表达生硬、格式错漏……这些问题像隐藏的陷阱,让无数学生陷入“改到崩溃”的循环。但如今,一款名为书匠策AI的科研工具正以“六维超能引擎”的姿态&#xff0…

作者头像 李华
网站建设 2026/6/7 22:43:22

Swin2SR使用技巧:避免显存崩溃的3个方法

Swin2SR使用技巧:避免显存崩溃的3个方法 本文约3800字,建议阅读9分钟 专为图像超分场景设计的Swin2SR模型,在实际部署中常因显存溢出导致服务中断。本文不讲理论推导,只分享3个经实测验证、可立即落地的显存保护方法——全部来自…

作者头像 李华
网站建设 2026/6/6 22:29:59

Qwen3-Reranker-4B实战:如何用vLLM轻松搭建排序服务

Qwen3-Reranker-4B实战:如何用vLLM轻松搭建排序服务 1. 引言 如果你正在构建一个智能问答系统或者文档检索工具,一定遇到过这样的问题:系统检索出来的文档虽然相关,但排序混乱,用户需要自己从一堆结果里找出最准确的…

作者头像 李华