动态工作流处于研究预览阶段。它们需要 Claude Code v2.1.154 或更高版本,在所有付费计划上可用,具有 Anthropic API 访问权限,以及在 Amazon Bedrock、Google Cloud Vertex AI 和 Microsoft Foundry 上可用。在 Pro 上,从
/config 中的”Dynamic workflows”行启用它们。- 决定何时使用工作流而不是子代理或 skills
- 运行捆绑工作流与
/deep-research - 让 Claude 为您的任务编写工作流并保存它
- 理解工作流如何运行和管理运行
何时使用工作流
子代理、skills、agent teams 和工作流都可以运行多步骤任务。区别在于谁掌握计划:| 子代理 | Skills | Agent teams | 工作流 | |
|---|---|---|---|---|
| 它是什么 | Claude 生成的工作者 | Claude 遵循的指令 | 监督对等会话的主导代理 | 运行时执行的脚本 |
| 谁决定接下来运行什么 | Claude,逐轮 | Claude,遵循提示 | 主导代理,逐轮 | 脚本 |
| 中间结果在哪里 | Claude 的上下文窗口 | Claude 的上下文窗口 | 共享任务列表 | 脚本变量 |
| 什么是可重复的 | 工作者定义 | 指令 | 团队定义 | 编排本身 |
| 规模 | 每轮几个委派任务 | 与子代理相同 | 少数几个长期运行的对等体 | 每次运行数十到数百个代理 |
| 中断 | 重启轮次 | 重启轮次 | 队友继续运行 | 在同一会话中可恢复 |
运行捆绑工作流
查看工作流运行的最快方式是运行/deep-research,这是 Claude Code 包含的内置工作流,用于跨许多来源调查问题。您将看到代理在后台通过一组阶段工作,同时您的会话保持空闲,最后获得一份报告而不是逐轮记录。
允许工作流
Claude Code 询问是否允许工作流。选择是继续。确切的提示取决于您的权限模式。有关每种模式的选项,请参阅在运行前批准计划。
观看进度
运行在后台启动。运行 该视图显示每个阶段及其代理计数、令牌总数和经过的时间。深入任何阶段以查看其代理及每个代理发现的内容。有关完整的控制集,请参阅观看运行。您也可以从输入框下方的任务面板观看:运行进行时会出现一行进度摘要。按向下箭头聚焦它,然后按 Enter 展开。
/workflows,使用箭头键选择运行,然后按 Enter 打开其进度视图:捆绑工作流
Claude Code 包含/deep-research 作为内置工作流:
| 命令 | 它做什么 |
|---|---|
/deep-research <question> | 在多个角度上扇出网络搜索问题,获取并交叉检查它找到的来源,对每个声明投票,并返回一份引用的报告,其中未通过交叉检查的声明已被过滤掉。需要WebSearch 工具可用 |
/ 自动完成中与捆绑的工作流一起出现。
观看运行
工作流在后台运行,所以会话在代理工作时保持响应。随时运行/workflows 列出运行中和已完成的工作流,然后选择一个打开其进度视图。
| 键 | 操作 |
|---|---|
↑ / ↓ | 选择一个阶段或代理 |
Enter 或 → | 深入选定的阶段,然后进入代理以读取其提示、最近的工具调用和结果 |
Esc | 返回一个级别 |
j / k | 当代理详情溢出时在其中滚动 |
p | 暂停或恢复运行 |
x | 停止选定的代理,或当焦点在运行上时停止整个工作流 |
r | 重启选定的运行中代理 |
s | 保存运行的脚本作为命令 |
让 Claude 编写工作流
您可以通过两种方式让 Claude 为您的任务编写工作流:- 在您的提示中请求工作流,使用关键字
ultracode,Claude 为任务编写一个。 - 让 Claude 使用 ultracode 决定:设置
/effort ultracode,Claude 为会话中的每个实质性任务规划工作流。
/deep-research,或一个您已保存的。
在您的提示中请求工作流
要在不改变会话的努力级别的情况下将单个任务作为工作流运行,在您的提示中包含关键字ultracode。用您自己的话提问,例如”使用工作流”或”运行工作流”,也可以工作:Claude 将直接请求视为相同的选择加入。在 v2.1.160 之前,字面触发关键字是 workflow;自然语言请求在两个版本中都有效。
Option+W 或在 Windows 和 Linux 上按 Alt+W 来忽略此提示的突出显示,或在突出显示的关键字后面的光标处按退格键。要完全停止该关键字触发,请在 /config 中关闭 Ultracode 关键字触发。
如果运行完成了您想要的操作,您可以之后将其保存为命令。
如果您已经用另一种方式构建了编排器,例如子代理提示的文件夹或一个分散工作的技能,您可以指向 Claude 并要求一个执行相同操作的工作流。
让 Claude 使用 ultracode 决定
Ultracode 是一个 Claude Code 设置,它结合了xhigh 推理努力与自动工作流编排。启用它后,Claude 为每个实质性任务规划工作流,而不是等待您要求。
/effort high 下降。它在支持 xhigh 努力的模型上可用;在其他模型上,/effort 菜单不提供它。
在运行前批准计划
在 CLI 中,每次运行的提示显示计划的阶段和这些选项:- 是,运行它:启动运行
- 是,不再为
<path>中的<name>询问:启动,并从现在起跳过此项目中此工作流的此提示 - 查看原始脚本:在决定前读取脚本
- 否:取消
Ctrl+G 在您的编辑器中打开脚本。Tab 让您在运行启动前调整提示。
您是否看到此提示取决于您的权限模式:
| 权限模式 | 何时提示您 |
|---|---|
| 默认,接受编辑 | 每次运行,除非您已为此项目中的该工作流选择是,不再询问 |
| 自动 | 仅首次启动。任何是在您的用户设置中记录同意,之后启动无需提示。当 ultracode 启用时完全跳过 |
绕过权限,claude -p,Agent SDK | 从不。运行立即启动 |
acceptEdits 模式下运行,并继承您的工具允许列表,无论您的会话模式如何。文件编辑自动批准。
Shell 命令、网络获取和不在您的允许列表中的 MCP 工具仍然可以在运行中提示您。要在长时间运行中避免这种情况,在启动前将代理需要的命令添加到您的允许列表。
在 claude -p 和 Agent SDK 中没有人提示,所以工具调用遵循您配置的权限规则,无需交互式确认。
保存工作流以供重用
当 Claude 为您将重复的任务编写工作流时,您可以将该运行的脚本保存为命令。像您在每个分支上运行的审查这样的过程然后每次运行相同的编排。 运行/workflows,选择您想保留的运行,然后按 s。在保存对话中,Tab 在两个保存位置之间切换:
.claude/workflows/在您的项目中:与克隆仓库的每个人共享~/.claude/workflows/在您的主目录中:在每个项目中可用,仅对您可见
/<name> 运行。
如果项目工作流和个人工作流共享名称,项目工作流运行。
将输入传递给保存的工作流
保存的工作流可以通过args 参数接受输入。脚本将其读取为名为 args 的全局变量。使用此功能在调用时提供研究问题、目标路径列表或配置对象,而不是为每次运行编辑脚本。
以下提示使用问题编号列表运行保存的工作流:
args 上调用数组和对象方法,无需先解析它。如果省略 args,脚本内的全局变量为 undefined。
工作流如何运行
工作流运行时在隔离环境中执行脚本,与您的对话分开。中间结果保留在脚本变量中,而不是进入 Claude 的上下文。 每次运行都会将其脚本写入您会话目录下~/.claude/projects/ 中的文件。运行开始时 Claude 会收到该路径,因此您可以要求它提供。您可以打开该文件来读取 Claude 编写的编排脚本,将其与之前运行的脚本进行对比,或编辑它并要求 Claude 从编辑后的版本重新启动。
运行时在运行进行时跟踪每个代理的结果,这是使运行在同一会话中可恢复的原因。
行为和限制
运行时应用以下约束:| 约束 | 为什么 |
|---|---|
| 无中途用户输入 | 仅代理权限提示可以暂停运行。对于阶段之间的签署,将每个阶段作为其自己的工作流运行 |
| 无来自工作流本身的直接文件系统或 shell 访问 | 代理读取、写入和运行命令。脚本协调代理 |
| 最多 16 个并发代理,在 CPU 核心有限的机器上更少 | 限制本地资源使用 |
| 每次运行 1,000 个代理总数 | 防止失控循环 |
管理运行
运行启动后,您可以从/workflows 视图管理它,或通过展开输入框下方任务面板中的其进度行来管理。
暂停后恢复
如果您停止运行,您可以恢复它:已完成的代理返回其缓存结果,其余的实时运行。从/workflows 恢复暂停的运行,选择它并按 p,或要求 Claude 使用相同脚本重新启动工作流。
恢复在同一 Claude Code 会话中工作。如果您在工作流运行时退出 Claude Code,下一个会话将从头启动工作流。
成本
工作流生成许多代理,所以单次运行可以使用比在对话中处理相同任务更多的令牌。运行计入您的计划使用和速率限制,如任何其他会话。 要在提交大型任务前评估支出,请先在小范围上运行工作流:一个目录而不是整个仓库,或一个狭窄的问题而不是一个宽泛的问题。/workflows 视图显示每个代理的令牌使用情况,随着运行进行,您可以随时在那里停止运行而不会丢失已完成的工作。运行时的代理上限限制单次运行可以生成多少个代理,这限制了失控脚本的成本。
工作流中的每个代理使用您的会话模型,除非脚本将阶段路由到不同的模型。要控制模型成本:
- 在大型运行前检查
/model,如果您通常为日常工作切换到较小的模型 - 当您描述任务时,要求 Claude 为不需要最强模型的阶段使用较小的模型
关闭工作流
工作流在 CLI、桌面应用、IDE 扩展、非交互模式与claude -p 和 Agent SDK 中可用。相同的禁用设置在每个表面上应用。
要为自己关闭工作流:
- 在
/config中切换”Dynamic workflows”关闭。在会话中持续。 - 在
~/.claude/settings.json中设置"disableWorkflows": true。在会话中持续。 - 设置
CLAUDE_CODE_DISABLE_WORKFLOWS=1。在启动时读取,所以它在您设置它的任何地方应用。
"disableWorkflows": true,或使用Claude Code 管理员设置页面上的切换。
当工作流被禁用时,捆绑工作流命令不可用,ultracode 关键字不再触发运行,ultracode 从 /effort 菜单中移除。