ZapMyCo
指南

内置工具

ZapMyCo 在 `zapmyco run` 模式下提供的 AI Agent 内置工具参考

ZapMyCo 的内置工具系统为 AI Agent 提供了与本地环境和用户交互的能力。大多数工具在 zapmyco run <content> 一次性执行模式下可用,而交互式工具(如 ask_usertask_*)在交互模式(zapmyco 无参数)下也可用。

工具速查

工具名称功能能力
web_fetch获取网页内容将指定 URL 的网页转换为 Markdown,供 AI 分析
web_search搜索网络搜索实时信息(新闻、文档、趋势等)
shell_exec执行命令在本地系统执行 shell 命令并返回输出
file_read读取文件内容按行号范围读取本地文件内容,支持分段查看
file_search搜索文件内容在本地文件系统中搜索文件内容,支持正则表达式
file_find查找文件按 glob 通配符模式(如 **/*.rs)在本地文件系统中查找文件
file_edit编辑文件内容五种模式:line_range(推荐)、append、insert_after、批量编辑、旧模式
file_write写入文件创建新文件或完整覆盖已有文件,含预读检查和二进制检测
ask_user询问用户向用户提出选项问题并获取回答,支持单选/多选和自定义输入
task_create创建任务创建新任务以跟踪复杂多步骤工作进度
task_get查看任务按 ID 获取单个任务的详情和状态
task_list列出任务列出当前所有任务及其状态概览
task_update更新任务更新任务的状态、字段和依赖关系

按类别浏览

网络工具

工具说明文档
web_fetch获取指定 URL 的网页内容查看详情
web_search搜索网络获取实时信息查看详情

AI Agent 会自动组合两者:先用 web_search 找到相关页面,再用 web_fetch 获取具体内容。

命令执行

工具说明文档
shell_exec在本地系统执行 shell 命令查看详情

执行命令前会弹出确认提示,需用户授权。

文件操作

工具说明文档
file_read读取文件内容,支持行号范围分段查看查看详情
file_search使用正则表达式搜索文件内容查看详情
file_find按 glob 模式按名称查找文件查看详情
file_edit对已有文件进行精确、安全的内容修改查看详情
file_write创建新文件或完整覆盖已有文件查看详情

文件操作工具之间可以组合使用:先用 file_find 定位文件,用 file_search 搜索内容,用 file_read 查看上下文,再用 file_editfile_write 进行修改。

交互工具

工具说明文档
ask_user向用户提出选项问题并获取回答查看详情

任务管理

工具说明文档
task_create创建新任务以跟踪工作进度查看详情
task_get按 ID 获取任务详情和状态查看详情
task_list列出所有任务及其当前状态查看详情
task_update更新任务状态、字段或依赖关系查看详情

AI Agent 会自动组合任务工具完成复杂工作流:先拆解为子任务、跟踪进度、按需查看详情、更新状态。


未来扩展

ToolHandler 枚举通过 #[non_exhaustive] 标记,预留了扩展能力,未来版本将持续新增工具数量。

版本新增工具说明
v0.29+web_fetch, web_search, shell_exec初始工具:网络获取、网络搜索、命令执行
v0.31+file_read, file_search, file_find文件操作:读取、内容搜索、文件查找
v0.32+file_edit, file_write, ask_user文件编辑、文件写入、用户询问
v0.33+task_create, task_get, task_list, task_update任务管理系统
v0.34+file_edit 重构新增 line_range、append、insert_after、批量编辑模式,内容验证算法
未来待定敬请期待

最佳实践

  • 组合使用:AI Agent 可自动组合多个工具,例如"搜索 Rust 最新版本 → 访问发布页面 → 总结变更内容"
  • description 参数:在 prompt 中说明为什么需要执行某个命令,有助于 AI Agent 生成更有意义的描述,方便你判断是否授权
  • 安全审慎:只授权你确认过且安全的命令,对于删除、修改系统配置等危险操作应当慎重
  • 大型页面限制web_fetch 对大文档页面输出上限为 100K 字符,AI 可能只能看到截断后的内容,复杂任务可考虑分步骤执行

相关文档

On this page