🚀 docx2md-picgo:Word 文档图片一键上传图床工具

🚀 docx2md-picgo:Word 文档图片一键上传图床工具

写完笔记导出 Word,图片全是 media/image1.png 本地路径?发到博客全部裂图?这个脚本帮你一条命令搞定。

www.cnblogs.com/wrold/p/196...


📖 简介

upload_to_picgo.py 是一个专为博客写作者设计的自动化脚本。

很多人习惯用 Word(.docx)写笔记,再转成 Markdown 发布博客。但转换后图片路径全是 media/image1.png 这类本地引用,上传到博客后图片全部无法显示。手动一张张上传图床再替换链接,91 张图就要操作 91 次,极其繁琐。

这个脚本配合 PicGo + GitHub 图床,实现全程自动化:

复制代码
Word 文档  →  提取图片  →  PicGo 上传  →  CDN 链接  →  新 MD 文件

一条命令,所有图片自动上传并替换链接,直接得到可发布的 Markdown 文件。


✨ 功能特性

  • 📦 自动解压 docx,无需手动操作,直接从 Word 文件提取图片
  • 🖼️ 智能重命名 ,图片自动加上文章名前缀(如 pikachu_image1.png),多篇文章不会相互覆盖
  • 🚀 调用 PicGo 本地 API,无需填写 Token,利用已有图床配置直接上传
  • 🌐 自动替换为 CDN 链接,支持 jsDelivr 加速
  • 📄 生成新 MD 文件,原文件保留不动,输出带图床链接的新文件
  • ⚠️ 失败提示,上传失败的图片会单独列出,不影响其他图片

🔧 适用场景

场景 说明
靶场 / CTF 笔记 Word 截图多,图片量大,手动替换极慢
技术博客写作 习惯用 Word 打草稿,最终发 Markdown
渗透测试报告 大量截图需要整理上传
任何 docx → MD 的工作流 只要有图片都适用

📋 前置要求

软件:

  • Python 3.10+
  • PicGo(需要启动并开启 Server)

PicGo 配置:

  • GitHub 图床已配置(仓库、分支、Token、存储路径)
  • PicGo-Server 已开启,端口默认 36677

检查方法:PicGo → 设置 → PicGo-Server → 确认开关为「开」

Python 依赖:

复制代码
pip install requests

⚙️ 配置说明

打开脚本,修改顶部配置区的变量:

ini 复制代码
# ========== 配置区(按需修改) ==========
PICGO_API = "http://127.0.0.1:36677/upload"   # PicGo Server 地址,一般不用改
CDN_BASE  = "https://cdn.jsdelivr.net/gh/你的用户名/你的仓库@main/img"  # 改成你自己的
​
DOCX_PATH = "pikachu.docx"           # Word 文件名
MD_PATH   = "pikachu靶场笔记.md"      # 转换好的 MD 文件名
OUTPUT_MD = "pikachu靶场笔记_图床版.md"  # 输出文件名

CDN_BASE 格式:

ruby 复制代码
https://cdn.jsdelivr.net/gh/GitHub用户名/仓库名@分支名/存储路径

例如:

复制代码

🚀 使用教程

Step 1:准备文件

将以下文件放到同一个文件夹

复制代码
📁 你的文章文件夹/
├── upload_to_picgo.py    ← 本脚本
├── pikachu.docx          ← 原始 Word 文件
└── pikachu靶场笔记.md    ← 已转换好的 MD 文件

MD 文件可以用 Pandoc 转换:pandoc pikachu.docx -o pikachu靶场笔记.md

Step 2:修改配置

打开 upload_to_picgo.py,修改配置区的文件名和 CDN 地址。

Step 3:启动 PicGo

确保 PicGo 正在运行,Server 开关已打开。

Step 4:运行脚本

bash 复制代码
cd 你的文章文件夹
python upload_to_picgo.py

Step 5:查看输出

markdown 复制代码
=======================================================
  🐾 Pikachu 靶场笔记 - 图片批量上传工具
=======================================================
📂 正在解压 pikachu.docx 提取图片...
✅ 共提取 91 张图片
​
🚀 开始上传图片到 PicGo...
​
  [01/91] 上传 pikachu_image1.png ... ✅ https://cdn.jsdelivr.net/gh/...
  [02/91] 上传 pikachu_image2.png ... ✅ https://cdn.jsdelivr.net/gh/...
  ...
​
=======================================================
📊 上传完成:成功 91 张,失败 0 张
✅ 已替换 91 处图片链接
📄 新 MD 文件已保存至:pikachu靶场笔记_图床版.md
​
🎉 全部完成!

得到 pikachu靶场笔记_图床版.md,图片全部替换为 CDN 链接,直接发博客 ✅


🔄 复用到其他文章

每次写新文章,只需修改配置区三行:

ini 复制代码
DOCX_PATH = "sqlmap.docx"
MD_PATH   = "sqlmap笔记.md"
OUTPUT_MD = "sqlmap笔记_图床版.md"

图片会自动命名为 sqlmap_image1.pngsqlmap_image2.png,与其他文章完全隔离,不会覆盖。


❓ 常见问题

Q:提示「无法连接 PicGo Server」

确认 PicGo 正在运行,且 PicGo-Server 开关已打开,端口为 36677

Q:提示「找不到 docx 文件」

确认脚本和 docx 在同一目录,或在配置区填写完整路径,例如:

python 复制代码
DOCX_PATH = r"D:\Backup\桌面\pikachu\pikachu.docx"

Q:图片上传成功但 MD 里链接没变

检查 MD 文件中图片引用格式是否为 media/imageX.png,其他格式暂不支持。

Q:部分图片上传失败怎么办

脚本会在最后列出所有失败的图片名,手动用 PicGo 上传这几张后,在 MD 里手动替换即可。


📦 获取脚本

bash 复制代码
# 直接下载
https://github.com/Tjsdrj/upload_to_picgo/releases  # 或你存放的仓库地址

📄 License

MIT License,自由使用和修改。


💡 推荐工作流: Word 写稿 → Pandoc 转 MD → 本脚本上传图片 → 发布博客,三步完成从笔记到博文的全流程。

相关推荐
JaydenAI17 小时前
[RAG在LangChain中的实现-04]常用的向量存储和基于向量存储的检索器
python·langchain·ai编程
Roselind_Yi17 小时前
【吴恩达2026 Agentic AI】面试向+项目实战(含面试题+项目案例)-1
人工智能·python·面试·职场和发展·langchain·gpt-3·agent
Alan GEO实施教练17 小时前
专利申请是否找代理机构:核心考量与决策逻辑拆解
大数据·人工智能·python
oyguyteggytrrwwwrt17 小时前
抄写YOLOE源码——先抄写ultralytics包,关于__init__.py
开发语言·python
berryyan18 小时前
🚀 Windows + RTX 5090 + ComfyUI 桌面版 安装 SageAttention 完全手册
人工智能·python
性感程序员在线debug18 小时前
Python yield 原理
python
Alan GEO实施教练18 小时前
实用新型专利申请代理机构选择:关键考量因素与实操要点讲解
java·开发语言·python
闲云lazycloud18 小时前
08-Java工程师的Python第八课-框架入门
python
是真的小外套18 小时前
第十一章:Flask入门之从零构建Python Web应用
前端·python·flask
Westward-sun.18 小时前
NLP 词向量实战:PyTorch 从零实现 CBOW(Word2Vec)全流程拆解
人工智能·pytorch·python·深度学习·自然语言处理·word2vec