docx批量转markdown脚本

写在前面

使用该方法只能转换格式比较简单的文档,包含表格的效果不是很好。

工具

转换需要使用到Pandoc工具。
Pandoc是由John MacFarlane开发的标记语言转换工具,可实现不同标记语言间的格式转换,堪称该领域中的“瑞士军刀”。
Pandoc下载链接

windows脚本

docx转markdown

@echo off

for /f "tokens=* delims=" %%i in ('dir /b *.docx') do (
  @echo %%i
  pandoc -f docx -t markdown -o "%%~ni.md" "%%i"
  @echo Finished
)

pause > nul

markdown转docx

@echo off

for /f "tokens=* delims=" %%i in ('dir /b *.md') do (
  @echo %%i
  pandoc -f markdown -t docx -o "%%~ni.docx" "%%i"
  @echo Finished
)

pause > nul

python脚本

脚本名称docx_to_md.py

import os

# 将中文部分替换为你想要的文件路径。
filepath = r'待转换文件所在文件夹'
destination_path = r'转换后文件所在文件夹'

# 检查转换后文件所在文件夹是否存在,不存在则创建。
if os.path.exists(destination_path):
    pass
else:
    os.makedirs(destination_path)

# os.listdir 命令列出待转换文件所在文件夹中所有文件的名称,包含 .xxx 后缀
file_names = os.listdir(filepath)

for file_name in file_names:

    # .rfind('.'),从左往右直到最后一个 . 的位置。
    index = file_name.rfind('.')

    # index == -1 即不存在 . 符号。
    if index != -1:

        # 将不带后缀的文件名储存到另一变量中。
        file_name_nosuffix = file_name[:index]

        # os.system 命令调用系统命令行。Linux 和 Mac 可能需要将 \ 替换为 /.
        os.system(f'pandoc {filepath}\{file_name} -f docx -t markdown -s -o {destination_path}\{file_name_nosuffix}.md')

终端执行脚本

$ python docx_to_md.py
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用 Python 中的 python-docx 和 BeautifulSoup 库来实现批量docx 到 html 的功能。具体步骤如下: 1. 安装 python-docx 和 BeautifulSoup 库 可以使用 pip 工具来安装这两个库。在终端中执行以下命令: ``` pip install python-docx pip install beautifulsoup4 ``` 2. 编写 Python 脚本Python 脚本中,首先需要导入 python-docx 和 BeautifulSoup 库,然后使用 python-docx 库打开 docx 文件,将其换为 HTML 字符串,最后使用 BeautifulSoup 库对 HTML 字符串进行解析和格式化,然后保存为 html 文件。 下面是示例代码: ```python import os from docx import Document from bs4 import BeautifulSoup # 设置源文件和目标文件夹 src_folder = './docx_files' dst_folder = './html_files' # 遍历源文件夹中的所有 docx 文件 for filename in os.listdir(src_folder): if filename.endswith('.docx'): # 打开 docx 文件 doc = Document(os.path.join(src_folder, filename)) # 将 docx 换为 HTML 字符串 html = doc._element.xml # 使用 BeautifulSoup 对 HTML 进行格式化 soup = BeautifulSoup(html, 'html.parser') pretty_html = soup.prettify() # 保存为 html 文件 with open(os.path.join(dst_folder, f'{filename[:-5]}.html'), 'w', encoding='utf-8') as f: f.write(pretty_html) ``` 这段代码会将 `./docx_files` 文件夹中的所有 docx 文件换为 html 文件,并保存到 `./html_files` 文件夹中。其中,`filename[:-5]` 表示去掉文件名中的后缀名,即将 `.docx` 后缀替换为 `.html`。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值