pdca
PDCA 项目管理系统
基于 PDCA 循环的结构化问题解决系统。AI Agent 驱动主动巡检、SMART 目标校验和 MECE 框架分析,支持飞书工具链作为深度集成后端。
何时使用
| 触发症状 | 不适用场景 |
|---|---|
| 问题需要结构化分析(5W1H、鱼骨图、5Why) | 简单单次任务(直接用任务管理工具) |
| 需要量化目标和可衡量指标 | 纯技术研究(无需流程闭环) |
| 需要主动进度监控和预警 | 紧急故障处理(先修复,后复盘) |
触发示例:
- "启动一个 PDCA 项目来降低产品缺陷率"
- "用飞书 Bitable 管理我们的质量改善项目"
- "我需要 SMART 目标校验,目标是将 OEE 提升到 85%"
- "检查一下我的 PDCA 项目进度"
平台与后端
Agent 平台:本技能不绑定任何特定 AI Agent 平台,可用于:
- OpenClaw(https://github.com/open-claw/open-claw)
- Hermes Agent
- Claude Code
- 任何能加载 Markdown 技能并执行工具调用的 Agent
工具后端(推荐:飞书):
- 飞书提供项目管理的全套工具链(Wiki 文档、Bitable 多维表格、Calendar 日历、Task 任务)
- 飞书集成实现详见 feishu-integration.md
- Bitable 表结构定义详见 Bitable表结构定义.md
最小可用模式:即使没有飞书,Agent 也可以用本地文件系统管理项目(文档 + JSON 状态文件),核心的 PDCA 方法论、MECE 分析、SMART 校验仍然完整可用。
核心特性
1. MECE 框架分析
根据问题类型选择对应的分析框架,确保维度覆盖完整、无遗漏无重叠:
| 问题类型 → 框架 |
|---|
| 生产/制造 → 4M1E |
| 个人健康 → TREND |
| 软件/技术 → PPTD |
| 销售/营销 → 5P |
| 学习/教育 → COMET |
| 财务/投资 → 3RL-TD |
| 团队协作 → GRCT |
| 客户服务 → 5S |
| 个人效率 → TIME |
| 流程/服务 → SIPOC |
| 其他管理/组织 → 5P2E |
每个框架的逐维度详细说明见 mece-frameworks.md。
2. 质量门(不可跳过)
3. 主动巡检(Agent 核心价值)
项目创建后无人跟进是 PDCA 失败的首要原因。 Agent 必须像项目经理一样定期主动检查进度。
- 每日进度检查(建议 09:00)
- 阶段到期前 2 天预警
- 里程碑到期提醒
- 进度偏差分析(时间进度 vs 完成度)
- 超时警告
完整行为规范见 proactive-reminder.md。
全局交互规范:选项设计
适用范围:PDCA 每个阶段中 AI 主动发起的选项对话。
设计选项时遵循三大原则:
1. MECE 原则 — 基于框架设计选项
选项必须"相互独立、完全穷尽"。根据当前对话的问题类型,选择对应的 MECE 框架维度作为选项基础(见上表)。
2. 多选优先 — 原因/因素往往不止一个
问题涉及"哪些方面"、"什么原因"、"什么因素"时,使用多选。
3. 允许自定义 — 必须有 Other 选项
所有问题必须包含自定义选项,因为无法预先覆盖所有情况。
选项设计 Red Flags
- 选项之间有明显重叠 → 基于 MECE 框架重新设计
- 用户说"原因是多个"但只能单选 → 改为多选
- 用户说"我的情况不在选项里" → 缺少自定义选项
- 没有基于任何框架直接编选项 → 先选择合适的框架
4. 平台感知交互 — 根据平台能力选择呈现方式
不同平台对交互组件的支持不同。Agent 必须根据当前运行平台的能力,自动选择最优的交互方式。选项内容不变(MECE 原则),变化的只是呈现载体。
飞书 Channel 网关模式(OpenClaw + openclaw-lark 插件)
当前可用方案:P1 交互式卡片 → P2 富文本编号列表
⭐ 推荐:feishu_ask_user_question 工具
OpenClaw 官方的 openclaw-lark 插件 提供了 feishu_ask_user_question 工具,支持完整的交互式卡片功能。
工具参数结构:
{
questions: [
{
question: "问题文本(支持 lark_md 格式)",
header: "短标签(最多12字符,如:'根因分析')",
options: [ // 空数组 = 文本输入,有内容 = 下拉选择
{ label: "选项A", description: "补充说明" },
{ label: "选项B", description: "补充说明" }
// ...
],
multiSelect: false // 单选 = false,多选 = true
}
// 最多4个问题
]
}
交互类型:
| options 配置 | multiSelect | 交互类型 | 适用场景 |
|---|---|---|---|
[] |
- | 文本输入框 | 自定义输入 |
| 有内容 | false |
单选下拉 | 确认/决策 |
| 有内容 | true |
多选下拉 | MECE 维度选择 |
| 不传 | - | 文本输入 | 默认行为 |
交互流程:
1. Agent 调用 feishu_ask_user_question
↓
2. 发送 CardKit v2 卡片(Form 容器 + form_action_type: "submit")
↓
3. 工具返回 { status: 'pending' }
↓
4. 用户填写并提交
↓
5. 系统注入 synthetic message(用户答案)
↓
6. Agent 继续处理,答案已包含在消息上下文中
调用示例:
// 单选示例:阶段转换确认
feishu_ask_user_question({
questions: [{
question: "**项目**:挖掘机臂架开裂改善\n**阶段**:Plan → Do\n\n请确认是否可以进行阶段转换:",
header: "阶段转换",
options: [
{ label: "✅ 确认转换", description: "所有必选任务已完成" },
{ label: "⏳ 延期", description: "需要更多时间" },
{ label: "❌ 返回", description: "返回当前阶段" }
],
multiSelect: false
}]
})
// 多选示例:MECE 维度选择
feishu_ask_user_question({
questions: [{
question: "**请选择导致问题的主要因素(可多选)**:",
header: "根因分析",
options: [
{ label: "🔧 设备/机器", description: "设备故障、老化、维护不当" },
{ label: "👤 人员/技能", description: "培训不足、流动性大" },
{ label: "📐 工艺/方法", description: "流程不合理、标准缺失" },
{ label: "📦 材料/物料", description: "原料质量、供应不稳定" },
{ label: "🌍 环境/条件", description: "温湿度、照明、噪音" }
],
multiSelect: true
}]
})
// 文本输入示例:自定义补充
feishu_ask_user_question({
questions: [{
question: "**请描述您的具体情况**:",
header: "补充说明",
options: [] // 空数组 = 文本输入框
}]
})
重要约束:
- 最多 4 个问题
- header 最多 12 字符
- 提交后会触发 synthetic message,Agent 需要从消息上下文中获取答案
备选方案:P2 富文本编号列表
当 feishu_ask_user_question 不可用时,使用文本编号列表作为 fallback:
**📋 [问题标题]**
[1-2 句背景说明]
请选择(可多选):
1️⃣ **选项 A** — 补充说明
2️⃣ **选项 B** — 补充说明
3️⃣ **选项 C** — 补充说明
4️⃣ **选项 D** — 补充说明
5️⃣ 其他(请描述)
💡 输入编号选择,多个选项用逗号分隔(如 1,3,5)
📖 详细指南:更多 CardKit v2 卡片模板和回调处理,见 feishu-interaction.md
CLI 模式(Hermes / OpenClaw 命令行)
当前可用方案:P0 原生交互组件 → P2 文本编号列表
在命令行模式下:
- ✅
clarify工具可用(原生支持多选/单选/自定义) - 🔄 备选:文本编号列表
平台检测
| 检测方式 | 说明 | 示例值 |
|---|---|---|
HERMES_SESSION_PLATFORM 环境变量 |
Hermes Agent 平台标识 | cli, feishu, telegram, discord |
| 平台适配器回调能力 | 检测 clarify 工具是否可用 |
可用 = CLI 模式 |
| 消息来源判断 | 飞书 channel vs CLI 终端 | 飞书 = P2,CLI = P0→P2 |
各平台推荐方案汇总
| 运行模式 | 首选方案 | 备选方案 | 说明 |
|---|---|---|---|
| OpenClaw 飞书 channel | P1 feishu_ask_user_question |
P2 文本编号列表 | openclaw-lark 插件支持 |
| Hermes Agent 飞书 | P2 文本编号列表 | - | 网关模式,使用文本编号 |
| OpenClaw CLI | P0 clarify 工具 | P2 文本编号列表 | 原生交互可用 |
| Hermes CLI | P0 clarify 工具 | P2 文本编号列表 | 原生交互可用 |
| 其他平台 | 平台原生组件 | P2 文本编号列表 | 根据平台能力判断 |
通用文本 Fallback 格式
当平台不支持原生交互组件和卡片时,使用以下格式:
**[问题标题]**
[1-2 句背景说明]
请选择最符合您情况的选项(可多选):
1️⃣ **选项A** — 补充说明
2️⃣ **选项B** — 补充说明
3️⃣ **选项C** — 补充说明
4️⃣ **选项D** — 补充说明
5️⃣ 其他(请描述您的具体情况)
💡 输入编号选择,多个选项用逗号分隔(如 1,3,5)
交互流程规范
无论使用哪种交互载体,Agent 的行为必须一致:
- 生成选项:基于 MECE 框架维度生成选项内容
- 选择载体:根据平台能力选择 P0/P1/P2
- 呈现选项:使用对应载体的格式发送
- 接收选择:解析用户回复(按钮回调 / clarify 返回 / 文本编号)
- 确认 + 下一步:向用户确认已选内容,推进流程
交互 Red Flags
- 所有平台一律用纯文本长问句 → 没有检测平台能力,应使用结构化选项
- OpenClaw 飞书 channel 不使用
feishu_ask_user_question→ 该工具可用且是推荐方案 - 提供选项但用户不知道怎么选(没有说明操作方式)→ 缺少操作提示
三大指令
new — 启动新项目
流程:
- 评估问题:根据问题类型选择 MECE 框架,引导用户进行结构化分析
- SMART 校验:量化目标,通过 SMART + 因果逻辑双重校验
- 创建项目结构:
- 项目文档(问题分析、目标、解决方案)
- 数据表(项目主表、任务表、数据记录表、执行日志表)
- 项目甘特图(阶段时间线、关键节点、里程碑)
- 生成执行计划:按 MECE 维度分解任务,设定时间节点
- 注册巡检:创建每日巡检 + 阶段到期预警 + 里程碑提醒
飞书后端实现:如果使用飞书,步骤 3-5 的具体 API 调用见 feishu-integration.md 的「项目创建流程」章节。
ongoing — 管理活跃项目
流程:
- 巡检:按 proactive-reminder.md 执行每日检查
- 状态更新:评估完成度、计算偏差、判定状态(正常/预警/超时)
- 预警推送:发现异常时发送预警消息,附带具体建议
- 阶段转换:检查转换条件,用户确认后进入下一阶段
- 巡检参数更新:阶段转换后更新巡检周期和预警阈值
achieve — 检索经验库
流程:
- 分析当前问题的领域和类型
- 匹配历史项目中的相似案例
- 推荐最佳实践和模板
- 如果是制造场景,参考 manufacturing-templates.md
渐进式披露:详细指南
根据当前任务,阅读对应的参考文档:
1. 主动巡检与驱动
- 主动巡检行为规范:见 proactive-reminder.md
- 定时任务配置:见 cron-driving.md
2. 飞书集成(推荐后端)
- API 调用与工具配置:见 feishu-integration.md
- 表结构定义:见 Bitable表结构定义.md
- 收集表配置:见 收集表配置指南.md
- 仪表盘组件配置:见 仪表盘组件配置.md
- 工作流自动化配置:见 工作流自动化配置.md
- Bitable 应用文档模板:见 Bitable应用文档模板.md
3. 各阶段执行指南
- Plan 阶段(规划/校验):见 plan-agent.md
- Do 阶段(执行/日志):见 do-agent.md
- Check 阶段(数据/评估):见 check-agent.md
- Act 阶段(决策/沉淀):见 act-agent.md
4. 质量与逻辑校验
- SMART 原则校验:见 smart.md
- 因果逻辑链审查:见 logic.md
- 阶段转换检查:见 transition-checklist.md
- 异常处理:见 exception-handling.md
5. 制造场景模板与其他
- OEE/质量改善模板库:见 manufacturing-templates.md
- 仪表板模板:见 dashboard-templates.md
- 任务自动生成:见 任务自动生成器.md
- 智能巡检频率:见 智能巡检频率.md
- 仪表板生成:见 仪表板生成器.md
- 表单配置:见 表单配置生成器.md
- 阶段转换检查表:见 阶段转换检查表.md
阶段概览
| 阶段 | 核心交付物 | 校验标准 |
|---|---|---|
| Plan | 问题分析、目标设定、解决方案 | SMART + 因果逻辑 |
| Do | 执行日志、进度报告、问题记录 | 任务完成率 + 数据完整性 |
| Check | 数据分析、效果评估、问题诊断 | 目标达成率 + 趋势分析 |
| Act | 行动决策、实施方案、知识总结 | 决策矩阵 + SOP 沉淀 |
核心规则
- SMART 校验和因果逻辑验证是强制的,不可跳过
- 阶段转换严格按顺序,需要当前阶段所有必选任务完成
- 所有阶段转换和项目结项必须经过用户确认
- 巡检发现异常必须主动推送,沉默的巡检等于没有巡检
- 项目数据的事实来源由工具后端决定(飞书 Bitable / 本地文件 / 其他)
- 主动巡检是 Agent 的核心职责,不是可选功能
通用 Red Flags
出现以下信号时,立即停止:
方法论 Red Flags
- 目标没有具体数字 → 回到 Plan,完成 SMART 校验
- "执行中再调整" → 目标不够清晰
- "快速补救一下" → 补救≠符合标准
- "老板在催,先开始吧" → 权威压力不是降低标准的理由
- "已经花了 X 周了" → 沉没成本不是跳过检查的理由
- 直接接受用户提供的原因而不验证 → 用 MECE 框架逐维度扫描
- 跳过某个 MECE 维度 → 必须有数据支持才能判定不相关
巡检 Red Flags
- 连续多天没有发送巡检消息 → 巡检机制可能失效
- 巡检只报"一切正常"但完成度没有变化 → 数据可能不准确
- 用户长期不响应 → 考虑降低频率或询问是否暂停
Rationalization 防御
| 借口 | 现实 |
|---|---|
| "MECE 太复杂,简单问一下就行" | 简单提问 = 遗漏关键因素,后期返工更浪费时间 |
| "选项已经覆盖所有情况了" | 你无法预知所有情况,必须有自定义选项 |
| "用户已经说了原因,不需要再分析" | 用户说的是症状,不是根因 |
| "单选就够了" | 现实中问题往往是多因素导致的,限制用户只能选一个会遗漏原因 |
| "简单项目不需要完整的 PDCA 结构" | 简单项目也需要完整的 PDCA 结构,才能保证质量 |
| "每天发消息太打扰了" | 连续 3 天状态相同时自动降为摘要模式,状态变化时才发详情 |
| "巡检发现了问题但用户没回复" | 发送预警就够了,尊重用户的节奏,不要催促 |
Violating the letter of the rules is violating the spirit of the rules.