md2wechat:一个专为 AI 时代设计的公众号排版与发布引擎,支持 Markdown 一键转精美排版、AI 智能配图
传统的公众号写作流程是极其割裂的:在编辑器里写完,手动调整格式,寻找配图,最后还要一张张上传图片到公众号后台。这种“搬运工”式的工作,早已跟不上 AI 时代的创作节奏。
md2wechat (md2wechat.cn) 的出现,标志着公众号创作从“手动挡”进化到了“自动驾驶”。它不只是一个排版工具,更是一个 Agent-native 的创作网关。你可以用最习惯的 Markdown 格式写作,剩下的排版、配图、上传,全部交给它一键完成。
一、 md2wechat是什么
md2wechat 是一款集成了 AI 创作逻辑的公众号高级排版与发布系统。它支持将 Markdown 文本实时转化为适配微信公众号环境的富文本或 HTML。其核心竞争力在于深度的 AI 集成——它不仅提供 40 多套专业主题,还内置了 AI 配图能力,并支持 MCP (Model Context Protocol)协议,这意味着像 Claude Code、Cursor 这样的 AI 助手可以直接调用它的能力,完成从创作到发布的全流程。

二、 核心特性
- 🤖 AI Agent 原生支持:深度适配 Claude Code、Codex 等 AI 编程与写作助手。通过 MCP 协议,你可以直接命令 AI:“帮我把这篇 Markdown 排版并存入我的微信草稿箱。”
- 🎨 43 个高级排版模块:针对微信公众号复杂的 HTML/CSS 限制,精心调校了 43 个高级组件(如特殊的卡片、引用、引导关注等),确保在各种机型上都能完美呈现。
- 🖼️ 智能图片自动化:
- AI 自动配图:根据文章语境,自动生成并插入契合主题的高质量图像。
- 图床自动托管:支持将本地或第三方图床图片一键上传至微信素材库,自动替换链接,告别“图片防盗链”烦恼。
- ⚡ 一键直达草稿箱:无需手动复制粘贴,直接调用微信官方 API,将排版后的成品同步到草稿箱,保留所有样式和多媒体元素。
- 🛠️ 开发者友好架构:
- 全流程 CLI:支持命令行操作,方便接入自动化脚本。
- RESTful API:支持批量转换与第三方系统集成,适合矩阵运营。
- 💻 极致编写体验:内置代码高亮(支持主流语言)、标准与扩展 Markdown 语法兼容,左侧编辑右侧实时预览,所见即所得。
三、 操作指南
- 配置环境:在网页端输入你的公众号凭证(AppID/Secret)或在本地设置环境变量。
- 撰写内容:在左侧区域使用 Markdown 写作,实时预览右侧 40+ 套主题的渲染效果。
- AI 赋能:利用内置模块添加高级组件,或调用 AI 生成封面图与配图。
- 一键推送:点击“同步到草稿箱”,稍后在手机微信公众平台预览、群发即可。
四、 支持平台
- 在线 Web 版:访问 md2wechat.cn 即可开始排版。
- 开源 CLI 工具:开发者可从 GitHub 下载
md2wechat-skill,集成到自己的 AI 创作流中。
五、 产品定价
基础排版免费,高级 API 随需调用。
平台提供免费的高质量排版服务,针对高频的 API 调用、批量发布及 AI 增值功能提供灵活的扩展方案,让个体创作者与专业机构都能低门槛接入。
六、 使用场景
- 技术博主:利用代码高亮和标准的数学公式支持,快速分享硬核干货。
- AI 创作者:通过 Agent 接口,让 AI 自动化完成“写、配图、排版、上传”的全链路。
- 矩阵运营团队:通过 API 接口实现内容的一键分发和标准化排版,极大提升运营效率。
- 深度写作者:追求 Dan Koe 等专业排版风格,让长文在手机端具备极佳的阅读呼吸感。
七、 运作模式
md2wechat 采用了 “语义解析 + 样式内联化 (Inline CSS)” 的技术路径。
由于微信公众号后台会过滤大部分外部样式表,md2wechat 在转换过程中,会将 40 多套精美主题的 CSS 属性逐行“注入”到 HTML 标签内部。同时,它利用 FFmpeg 和 Sharp 等底层工具处理媒体资源,确保图片在高压缩率的同时保持清晰。最前沿的 MCP 支持 则让它成为了 AI 助手的“手脚”,让 AI 能够理解并执行复杂的微信图文发布指令,实现了从“辅助写作”到“自主发布”的跨越。
结语
写作的本质是思考,而不应是排版。md2wechat 将繁琐的微信后期工作压缩到了极致,并为未来的 AI 自动化生产铺好了路。如果你希望让公众号写作变得像发朋友圈一样轻快,这个 AI 时代的创作工作台,绝对值得你立刻上手。
官方地址: https://md2wechat.cn/
GitHub 仓库: https://github.com/geekjourneyx/md2wechat-skill
