前言
最近,Coze 推出了对话创建 Agent 的功能,不少新手只需一句话就能快速生成基础 Agent,确实省时省力,但总觉得少了一点亲手操控的乐趣。说实话,要想真正理解 Agent 的工作原理,还是得从手动搭建工作流开始——每一个节点、每一次连接,都是自己深思熟虑后的选择。只有这样,才能打造出真正满足需求、并且可以灵活扩展的专属工具。
今天,我们就以儿童睡前故事 Agent为例,手把手带你从零开始手动搭建一条完整的工作流,一起看看:一个既能写故事、又能配语音的智能体,背后究竟是如何一步步运作的。
一、为什么选择儿童睡前故事?
儿童睡前故事是家庭中的高频刚需,需求明确、逻辑清晰,非常适合作为第一个工作流练手项目。这次我们要打造的 Agent,绝不只是简单“写个故事”,而是要做到:
- 根据孩子的喜好和当天的经历定制主题
- 自动适配故事时长,控制叙事节奏
- 融入正向教育主题,情节温馨无惊吓
- 生成文字故事的同时,还能合成温柔舒缓的睡前语音
二、准备工作:2 分钟快速上手 Coze
无需下载软件,直接打开 Coze 官网即可开始:
- 用手机号或抖音账号登录,进入开发者后台;
- 现在 Coze 已支持对话创建 Agent(如下图所示),但今天我们不走捷径,手动搭建工作流;
- 先了解 3 个核心模块:角色提示词、知识库、测试页面,它们是整个流程的基石。
三、Step by Step:手动搭建你的第一个工作流
Step 1:新建空白工作流
点击确认进入以下界面:
Step 2:按逻辑一步步配置节点
1. 生成搜索词:把模糊需求转化为精准指令
很多新手直接让大模型写故事,容易导致内容重复、情节老套。因此我们先增加一个「生成搜索词」节点,将用户的口语化需求,转换成能够搜到优质素材的关键词。
- 使用「豆包·通用模型·Lite」模型
(如果使用太大的模型会搜索到更多内容,但运行时间会很长),在提示词中明确说明:
输入:选择「开始」节点的输出 str.input(将用户的睡前故事需求传递进来)
输出:设置为 str.queries(保存生成的搜索词);
- 这样后续的搜索环节,就能获取更贴合需求的素材,避免生成的故事千篇一律。
- 用「连接线」将「开始」节点的输出端,连接到「生成query」的输入端。(连接并重新命名大模型)
2. 循环搜索:为故事寻找“新鲜灵感”
我们不直接使用大模型的“知识库”,而是增加一个循环 + 联网搜索的结构,这样每次生成的故事都能使用新素材,不会总是重复同一个老童话。
- 添加「循环」节点,绑定上一步生成的搜索词;
- 在循环体内加入「联网搜索」插件,批量获取儿童睡前故事、温馨童话素材;
- 你可以自行控制搜索数量和关键词范围,比自动生成的 Agent 更灵活。
3. 撰写草稿:整合素材,写出故事初稿
获取素材后,用「大模型」节点编写故事草稿。这里的提示词至关重要:
- 设定规则:结合用户需求和搜索到的素材,生成结构完整、具有正向引导的故事;
- 可以在提示词中加入细节偏好,比如“多用小动物角色,少用神话怪兽”,这些是对话创建 Agent 很难精确控制的。
4. 润色优化:让故事更具睡前氛围
写完草稿后,再增加一个独立的「润色」节点,将故事改写成更适合睡前讲的版本:
- 简化长句,增加拟声词和童趣表达;
- 调整叙事节奏,使结尾更温柔舒缓;
- 这一步能明显提升故事的“可听性”,帮助孩子更容易进入睡前状态。
5. 语音合成:一键生成有声故事
最后,添加「语音合成」插件,将文字故事转换为温柔的语音。
- 你可以自行选择音色(注意部分音色需要会员,新手可以先选免费音色);
- 生成的语音链接可直接分享,无需额外导出,睡前点开就能播放。
6. 结束节点:整合结果输出
将「润色」和「语音合成」的输出都连接到「结束」节点,整个工作流就完成了。最终会同时返回故事文案和语音链接,一次性满足文字和有声的双重需求。
Step 3:试运行与调试
点击右上角的「试运行」,输入测试需求,例如:“给 5 岁的小朋友写一个关于小兔子的 10 分钟睡前故事,主题是学会分享”。等待几秒,就能看到生成的故事文案和语音链接,效果完全可用。如果觉得不满意,随时可以调整节点的提示词和配置——这正是手动搭建工作流的优势,每一步都在你的掌控之中。
四、发布你的专属 Agent
调试无误后,点击「发布」,为 Agent 起一个名字、设置头像,即可上线。你可以发布到 Coze 平台,也可以分享给朋友,甚至同步到掘金等社区。
结语
对话生成的 Agent 就像“预制菜”,方便快捷但千篇一律;而手动搭建的工作流,每一个节点的选择、每一句提示词的打磨,都是自己的思考与创造,就像亲手做的家常菜,更懂自己的口味,也能在这个过程中真正理解 Agent 的运作逻辑。当你听到自己搭建的 Agent 生成的语音里传来那段温柔的睡前故事时,那种成就感,是一键生成永远无法替代的。
