#开源推广 #开源项目 #Claude
详细内容见: https://github.com/TokenRollAI/claude-code-workflow-research
一句话:Claude Code workflow 不是模型自己在一次请求里并发工作,而是主模型先写一段 JavaScript 编排脚本,Claude Code 本地 runtime 执行这段脚本,按脚本启动多个子代理,再把子代理的结构化 JSON 结果串起来。
用户显式触发 workflow
-> 主模型看到 Workflow 本地工具
-> 主模型生成一段 JS workflow script
-> Claude Code 本地 runtime 执行 JS
-> JS 里的 agent() 启动多个普通子代理请求
-> 子代理通过 StructuredOutput 返回 JSON
-> runtime 把 JSON 当作 agent() 的返回值传给后续 JS
-> JS 最终 return 一个对象
-> Claude Code 用 <task-notification> 把结果回灌主会话
Workflow 是本地工具,不是 Anthropic API 的一个特殊 endpoint 。agent(prompt, { schema }) 会启动一个子代理,并强制它调用 StructuredOutput。JSON.stringify(...) -> 下一个 agent 的 prompt 。pipeline() 默认没有阶段 barrier ,某个 item 完成一阶段就能进入下一阶段。parallel() 是 barrier ,只适合确实需要等全部结果时使用。<task-notification> 注入回主会话。一次 workflow 子代理请求不是一个巨大的纯文本 prompt ,而是多个槽位组合:
| 槽位 | 放什么 |
|---|---|
messages[0].content |
子代理本轮 user 输入,包含系统提醒和 JS 生成的任务 prompt 。 |
system[] |
Claude Code 身份、workflow subagent 规则、环境信息。 |
tools[] |
Bash/Read/Skill 等工具,以及动态生成的 StructuredOutput。 |
StructuredOutput.input_schema |
JS 里传给 agent(..., { schema }) 的 schema 。 |
本次例子里,judge prompt 是这样来的:
agent(
`你是桌游评委,专门从这个维度评审:「${j.desc}」。\n` +
`待评概念:\n${JSON.stringify(concept, null, 2)}\n` +
`请给出 1-10 分并简述理由。用中文作答。`,
{ schema: JUDGE_SCHEMA }
)
这里的 concept 是 invent agent 通过 StructuredOutput 返回的 JSON 。也就是说,下游 prompt 看到什么,完全取决于 JS 作者显式拼进去什么。
这次 workflow 是一个“桌游设计锦标赛”:
最终通知里也记录了:
<agent_count>21</agent_count>
<subagent_tokens>232900</subagent_tokens>
<duration_ms>257654</duration_ms>
Claude Code workflow 把“多代理协作”从自然语言群聊变成了可执行的数据流程序:agent() 像异步函数,prompt 是输入,StructuredOutput JSON 是返回值,pipeline() 和 parallel() 是调度结构,最终 return 是结果。
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.