WeFlow 群聊总结器
设置和运行 WeChat 群聊定期总结。所有脚本和配置都在此技能目录下(<skill_dir> 即本 SKILL.md 所在目录)。
前置条件:
- WeFlow 桌面端已在运行,且 API 服务已启用(设置页面 → API 服务 → 启动服务)
- Python 3 已安装
- 安装依赖:
pip install pyyaml openpyxl
目录结构:
scripts/ Python 脚本
weflow-proxy/ Go 反向代理(跨机器访问 WeFlow API 时需要)
reference/ API 文档
weflow-groups.yaml 配置模板(勿直接修改,复制到工作目录使用)
Step a: 检查 WeFlow 连接
python3 <skill_dir>/scripts/check_weflow.py
如果成功(输出 host 地址)→ 进入 Step b。
如果失败,先排查:
- WeFlow 是否在运行?
- API 服务是否已启用?(WeFlow 设置 → API 服务 → 启动服务,默认端口 5031)
- 如果 WeFlow 在同一台机器:检查端口
lsof -i :5031 - 如果 WeFlow 在其他机器(如 Windows VM)→ 需要部署代理,见下方
部署代理(WeFlow 在远程机器时)
- 确认本机已安装 Go(
go version)。如未安装:brew install go(macOS) - 编译 Windows 代理:
cd <skill_dir>/weflow-proxy && ./build-windows.sh - 告知用户
weflow-proxy.exe的完整路径,请用户复制到 Windows 机器并在命令行(cmd/PowerShell)中运行。注意:Windows 防火墙可能拦截,需要允许通过 - 代理启动后会输出局域网地址,如:
如果显示多个 IP,选择与本机同一子网的地址。请用户提供该地址weflow-proxy listening 您可通过此地址访问 Weflow API: http://192.168.1.100:5032 - 验证:
python3 <skill_dir>/scripts/check_weflow.py --host http://<windows-ip>:5032 - 如果验证仍然失败:确认代理还在运行、Windows 防火墙已放行 5032 端口、VM 网络为桥接模式(非 NAT)
Step b: 获取群聊列表
python3 <skill_dir>/scripts/fetch_groups.py <HOST>
输出格式:
1. 群名A [12345678@chatroom]
2. 群名B [87654321@chatroom]
展示列表给用户,让用户选择要监控的群聊。用户可选多个,对每个群重复 Step c。
Step c: 配置群聊
首先准备配置文件(仅首次):
cp <skill_dir>/weflow-groups.yaml <用户指定路径>/weflow-groups.yaml
让用户选择存放位置,后续统一使用此路径(记为 CONFIG)。
对每个选中的群聊,依次收集:
1. 总结提示词
询问用户希望如何总结群消息。示例:
"简洁总结今天的讨论要点""你是情报分析专家,挖掘群聊中的高价值信息""关注技术讨论,忽略闲聊"
2. 关注特定群友(可选)
如果用户需要单独追踪某些群友的发言:
- 请用户从 WeFlow 导出群成员:WeFlow 界面 → 群聊分析 → 群成员查看 → 导出成员(生成 .xlsx 文件)。如果用户还没有文件,等用户提供后再继续
- 运行转换脚本(仅生成 JSON,不修改配置):
输出文件为python3 <skill_dir>/scripts/convert_members.py <xlsx文件><xlsx文件名>_members.json,格式:{"wxid_xxx": "昵称(群昵称)"} - 询问用户要关注谁,用
grep在 JSON 中搜索:grep "张三" <生成的_members.json> - 将匹配的 wxid 展示给用户确认
3. 写入配置
python3 <skill_dir>/scripts/add_group.py CONFIG \
--host <HOST> \
--talker <chatroom_id> \
--name "群聊名称" \
--summary-prompt "总结提示词" \
--members /path/to/members.json \
--subscribe-members wxid_1 wxid_2
--host仅首次需要--members使用绝对路径(即 convert_members.py 输出中Written to后的路径)--subscribe-members可选,建议与--members一起使用以显示昵称- 修改已有群聊:加
--update标志
Step d: 配置心跳
心跳即定期运行以下命令来检查新消息并生成总结。CONFIG 即 Step c 中复制的配置文件路径。
心跳执行命令:
python3 <skill_dir>/scripts/fetch_messages.py CONFIG
如果脚本报错(连接失败、配置缺失等),将错误信息报告给用户,不要回复 HEARTBEAT_OK。
处理脚本输出:
- 如果所有群的输出都包含
无新消息→ 回复HEARTBEAT_OK - 如果有新消息 → 脚本会输出每个群的消息,格式如下:
群名:工作群
用户要求:简洁总结今天的讨论要点
近期群信息:
[2026-03-10 09:15] 张三: 会议改到下午3点
[2026-03-10 09:20] 李四: 好的,已通知客户
[2026-03-10 10:00] 王五: [图片] /path/to/image.jpg
另外总结关注群友的发言:
张三说:
1. 会议改到下午3点
对每个有新消息的群:
- 将「用户要求」作为总结指令
- 根据指令总结「近期群信息」中的内容
- 如有「关注群友的发言」部分,单独总结
- 如有图片路径,读取图片并在总结中描述内容
- 跳过无新消息的群,不需要提及