您现在的位置是:网站首页 > 博客日记 >

python批量将docx转为pdf|异步

作者:YXn-python 阅读量:67 发布日期:2024-05-21

import os
import asyncio
from docx2pdf import convert

# pip install docx2pdf
"""
异步 docx文件转pdf 无需等待,不会阻塞转换
"""


# docx文档转pdf
async def docx_to_pdf(docx_path, save_path=None):
    if save_path:
        pdf_path = os.path.join(os.path.dirname(docx_path), save_path, os.path.basename(docx_path)[:-5] + '.pdf')
    else:
        pdf_path = os.path.splitext(docx_path)[0] + '.pdf'

    await convert(docx_path, pdf_path)

    print(f'{docx_path}转换成功!')


async def main(docx_urls):
    tasks = []
    for url in docx_urls:
        task = asyncio.create_task(docx_to_pdf(url, 'pdf'))
        tasks.append(task)
    await asyncio.gather(*tasks)


def run():
    while True:
        f_path = str(input('请(拖入/输入)(docx文件/文件夹)地址: '))
        if not os.path.exists(f_path):
            print('不存在该文件或文件夹,请重新输入!')
            continue
        if os.path.isfile(f_path):
            if os.path.splitext(f_path)[1] != '.docx':
                print('不支持的格式,请输入docx文件!')
                continue
        break
    if os.path.isdir(f_path):
        if not os.path.isdir(os.path.join(f_path, 'pdf')):
            os.mkdir(os.path.join(f_path, 'pdf'))
        # 获取文件夹下所有docx文件
        files = [os.path.join(f_path, file) for file in os.listdir(f_path) if file.endswith('.docx')]
        if len(files) == 0:
            print('文件夹下没有docx文件!')
            return
        loop = asyncio.get_event_loop()  # 开启事件循环对象
        loop.run_until_complete(main(files))  # 用事件循环对象开启协程异步对象
    elif os.path.isfile(f_path):
        docx_to_pdf(f_path)
    print('转换完成!')


if __name__ == '__main__':
    run()
    input('按回车退出...')

YXn-python

2024-05-21