Python实现Word文档转换Markdown的示例


Posted in Python onDecember 22, 2020

随着SaaS服务的流行,越来越多的人选择在各个平台上编写文档,制作表格并进行分享。

同时,随着Markdown语法的破圈,很多平台开始集成支持这种简洁的书写标记语言,这样可以保证平台上用户文档样式的统一性。

但是在一些场景下,我们还是会在本地的Office软件上写有很多文档,或者历史遗留了很多本地文档。

如果我们需要将其上传到各大平台,直接复制粘贴,大概率是会造成文档内容结构和样式的丢失。于此我们需要将其转换为 Markdown 语法。

很多桌面软件(比如Typora)都提供了导入 Word 文件的功能,这类功能一般是通过 Pandoc 这个软件来扩展实现的。

Pandoc 是一个全能型的文档格式转换工具,其能够将多种文档格式转换为各类常见的文档格式。具体的文档格式之间的转换如下图所示(来源于官网):

Python实现Word文档转换Markdown的示例

Pandoc 是瑞士军刀一般的存在,能够较好的处理各类的文档格式转换,但是如果我们需要自己写程序,调用 Pandoc 则需要额外的安装 Pandoc 才行,并且也不方便自定义。

幸而,在 Python 中有很多第三方模块提供了此类文档格式的转换功能。今天,我们来实现一下比较频繁使用到的 Word 文档转 Markdown 文档。

转换逻辑

Word 文档到 Markdown 文档的转换总体而言分两步来实现:

  • 第一步,将 Word 文档转换为 HTML 文档;
  • 第二步,将 HTML 文档转换为 Markdown 文档;

依赖模块

要实现这个功能我们需要借助 Python 的两个第三方模块:

  • mammoth
  • markdownify

mammoth 是一个用于将 Word 文档转换为 HTML 的模块,它支持在 Python、JavaScript、Java、.Net等平台使用。而 markdownify 则是将 HTML 转换为 Markdown 文档的模块。

处理 Word 图片

因为 Word 文档中不可避免地会存在很多图片,为了在转换后的文档中能够正确地显示图片,我们需要自定义一下Word 文档内图片的处理方式。默认情况下,mammoth 会将图片转换为 base64 编码的字符串,这样不用生成额外的本地图片文件,但是会使文档体积变得很大。所以我们选择将图片另存为本地图片:

# 转存Word文档内的图片
def convert_img(image):
  with image.open() as image_bytes:
    file_suffix = image.content_type.split("/")[1]
    path_file = "./img/{}.{}".format(str(time.time()),file_suffix)
    with open(path_file, 'wb') as f:
      f.write(image_bytes.read())

  return {"src":path_file}

正式转换

在这里,我们以州的先生很久以前写的《Python爬虫实战与机器学习应用》(需要这本书的小伙伴可以微信私聊我)这本书的 Word 文档来演示。

Python实现Word文档转换Markdown的示例

代码如下所示:

# 读取Word文件
with open(r"F:\自媒体\Python爬虫实战与机器学习应用.docx" ,"rb") as docx_file:
  # 转化Word文档为HTML
  result = mammoth.convert_to_html(docx_file,convert_image=mammoth.images.img_element(convert_img))
  # 获取HTML内容
  html = result.value
  # 转化HTML为Markdown
  md = markdownify(html,heading_style="ATX")
  print(md)
  with open("./docx_to_html.html",'w',encoding='utf-8') as html_file,open("./docx_to_md.md","w",encoding='utf-8') as md_file:
    html_file.write(html)
    md_file.write(md)
  messages = result.messages

运行程序,最终生成2个文件:

  • docx_to_html.html
  • docx_to_md.md

其中,docx_to_html.html 是 Word 文档转换为 HTML 后的文档:

Python实现Word文档转换Markdown的示例

docx_to_md.md 是 HTML 转换为 Markdown 后的文档:

Python实现Word文档转换Markdown的示例

最后是另存为的图片:

Python实现Word文档转换Markdown的示例

怎么样,简单的二三十行代码就完成了 Word 到 Markdown 文档的转换,是不是很简单?

此功能将集成到觅道文档作为文档导入的功能实现,欢迎持续进行关注!

  文章版权所有:州的先生博客

  原文地址:https://zmister.com/archives/1601.html

以上就是Python实现Word文档转换Markdown的示例的详细内容,更多关于python Word文档转换Markdown的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
Python2中的raw_input() 与 input()
Jun 12 Python
在Python中,不用while和for循环遍历列表的实例
Feb 20 Python
对python中UDP,socket的使用详解
Aug 22 Python
使用Python开发个京东上抢口罩的小实例(仅作技术研究学习使用)
Mar 10 Python
python中wx模块的具体使用方法
May 15 Python
详解Python中的编码问题(encoding与decode、str与bytes)
Sep 30 Python
python爬虫筛选工作实例讲解
Nov 23 Python
Django 权限管理(permissions)与用户组(group)详解
Nov 30 Python
python用分数表示矩阵的方法实例
Jan 11 Python
matplotlib 范围选区(SpanSelector)的使用
Feb 24 Python
用python自动生成日历
Apr 24 Python
还在手动盖楼抽奖?教你用Python实现自动评论盖楼抽奖(一)
Jun 07 Python
python爬虫利用selenium实现自动翻页爬取某鱼数据的思路详解
Dec 22 #Python
Django中ORM的基本使用教程
Dec 22 #Python
python通用数据库操作工具 pydbclib的使用简介
Dec 21 #Python
Python 多进程原理及实现
Dec 21 #Python
python-图片流传输的思路及示例(url转换二维码)
Dec 21 #Python
python 用pandas实现数据透视表功能
Dec 21 #Python
python 生成正态分布数据,并绘图和解析
Dec 21 #Python
You might like
PHP输出XML到页面的3种方法详解
2013/06/06 PHP
php利用cookies实现购物车的方法
2014/12/10 PHP
php使用正则表达式获取图片url的方法
2015/01/16 PHP
php与python实现的线程池多线程爬虫功能示例
2016/10/12 PHP
基于php编程规范(详解)
2017/08/17 PHP
javascript数组组合成字符串的脚本
2021/01/06 Javascript
网页中CDATA标记的说明
2010/09/12 Javascript
node.js中的console.log方法使用说明
2014/12/09 Javascript
详解JavaScript基于面向对象之继承
2015/12/13 Javascript
基于JS实现EOS隐藏错误提示层代码
2016/04/25 Javascript
js简单实现调整网页字体大小的方法
2016/07/23 Javascript
Node.js设置CORS跨域请求中多域名白名单的方法
2017/03/28 Javascript
ionic实现下拉刷新载入数据功能
2017/05/11 Javascript
nodejs基于mssql模块连接sqlserver数据库的简单封装操作示例
2018/01/05 NodeJs
360doc网站不登录就无法复制内容的解决方法
2018/01/27 Javascript
Angular 中使用 FineReport不显示报表直接打印预览
2019/08/21 Javascript
layer.confirm点击第一个按钮关闭弹出框的方法
2019/09/09 Javascript
vant picker+popup 自定义三级联动案例
2020/11/04 Javascript
[03:00]2014DOTA2国际邀请赛 Titan淘汰潸然泪下Ohaiyo专访
2014/07/15 DOTA
Python获取脚本所在目录的正确方法
2014/04/15 Python
Python中的index()方法使用教程
2015/05/18 Python
深入探究Django中的Session与Cookie
2017/07/30 Python
对pandas将dataframe中某列按照条件赋值的实例讲解
2018/11/29 Python
Python中logging.NullHandler 的使用教程
2018/11/29 Python
详解python中docx库的安装过程
2019/11/08 Python
用opencv给图片换背景色的示例代码
2020/07/08 Python
Python局部变量与全局变量区别原理解析
2020/07/14 Python
天网面试题
2013/04/07 面试题
建筑行业的大学生自我评价
2013/12/08 职场文书
简单而又朴实的个人求职信分享
2013/12/12 职场文书
民事诉讼授权委托书范文
2014/08/02 职场文书
中学生爱国演讲稿
2014/09/05 职场文书
爱心助学感谢信
2015/01/21 职场文书
2015入党个人自传范文
2015/06/26 职场文书
2016年教师党员承诺书范文
2016/03/24 职场文书
Vue实现跑马灯样式文字横向滚动
2021/11/23 Vue.js