自动将 HTML 格式的文章发布到微信公众号草稿箱,支持封面图上传、标题、作者和摘要等元数据管理。
⚡ 快速开始
最简单的用法:
python publisher.py --title "文章标题" --content article.html
完整参数:
python publisher.py \
--title "标题" \
--content article.html \
--author "作者名" \
--cover cover.png \
--digest "文章摘要"
默认值:
-
作者:
YanG -
封面图:
cover.png
📋 执行步骤
发布文章到微信草稿箱的完整流程:
- 查找 HTML 文件
优先查找 *_formatted.html(formatter 输出)
-
回退到最新的
.html文件 -
提取文章标题
从 HTML 注释提取:<!-- Title: xxx -->
-
从文件名提取
-
询问用户
-
检查封面图
查找 cover.png
-
如缺失则警告但继续发布
-
调用发布脚本
python publisher.py --title "xxx" --content xxx.html --cover xxx.png
- 验证结果
确认草稿创建成功
-
获取草稿 media_id
-
提示用户
提供微信后台链接
- 说明下一步操作
🔧 配置要求
首次使用
工具会在首次运行时引导配置:
- 获取微信公众号凭证
-
进入 设置 → 基本配置
-
复制 AppID 和 AppSecret
-
运行发布器
python publisher.py --title "测试" --content test.html
- 添加服务器 IP 到白名单(如需要)
配置文件
位置: ~/.wechat-publisher/config.json
格式:
{
"appid": "wx1234567890abcdef",
"appsecret": "your_secret_here"
}
✨ 核心功能
-
✅ access_token 自动缓存(有效期 7200 秒)
-
✅ 封面图上传和管理
-
✅ HTML 内容自动优化(适配微信)
-
✅ 字段长度自动截断(标题/作者/摘要)
-
✅ 错误处理和重试机制
-
✅ 中文错误提示和解决方案
-
✅ 交互模式和命令行模式
🛠️ 工作流集成
与其他 skill 协同工作:
完整工作流:
-
wechat-tech-writer→ 生成文章(xxx_article.md+cover.png) -
wechat-article-formatter→ 格式化 HTML(xxx_formatted.html) -
wechat-draft-publisher→ 发布到微信草稿箱(本 skill)
自动检测机制:
-
自动查找
*_formatted.html文件 -
自动查找
cover.png封面图 -
自动识别内容图片
🚨 常见问题
错误:IP 不在白名单
症状: invalid ip not in whitelist
解决:
-
登录微信公众号后台
-
进入 设置 → 基本配置
-
添加服务器 IP 到白名单
错误:AppSecret 错误
症状: AppSecret error
解决:
-
检查配置文件:
~/.wechat-publisher/config.json -
验证 AppID 以 "wx" 开头(18 个字符)
-
确认 AppSecret 正确
错误:标题/作者超出限制
症状: title/author size out of limit
解决:
-
工具会自动截断(标题:32 字节,作者:20 字节)
-
如需调整,修改
publisher.py
📁 文件结构
wechat-draft-publisher/
├── SKILL.md # 本文件
├── publisher.py # 核心发布脚本
├── scripts/ # 工具脚本
│ ├── fix-wechat-style.py # HTML 优化器
│ ├── optimize-html.py # HTML 压缩工具
│ ├── publish-workflow.sh # 完整工作流
│ ├── install.sh # 安装助手
│ └── test.sh # 测试脚本
├── examples/ # 示例文件
│ ├── config.json.example # 配置示例
│ └── example.html # HTML 示例
└── README.md # 详细英文文档
💡 使用示例
示例 1:标准发布
python publisher.py \
--title "VSCode 更名事件" \
--content article.html
示例 2:完整元数据
python publisher.py \
--title "技术文章" \
--content article.html \
--author "YanG" \
--cover images/cover.png \
--digest "这是一篇关于..."
示例 3:交互模式
python publisher.py --interactive
📱 发布后操作
发布成功后:
-
登录微信公众号后台
-
进入"草稿箱"
-
预览效果
-
确认后发布
注意事项:
-
⚠️ 草稿保存在微信后台,不会立即发布
-
⚠️ 可以在草稿箱中编辑后再发布
-
⚠️ 封面图会在预览时显示
🔗 相关文档
-
详细文档: README.md(英文)
-
安装指南: scripts/install.sh
-
HTML 处理: scripts/fix-wechat-style.py