python文件docx转pdf

centos部署的django项目,使用libreoffice做文件转换,官网给环境安装好libreoffice后,可使用命令行来进行转化

还可转换其他的各种格式,本文只做了pdf转换

python 复制代码
import subprocess    
import os    
  
def convert_to_pdf(input_file, output_file):    
    # 检查文件扩展名    
    if input_file.endswith('.docx'):    
        extension = '-convert-to pdf'    
    elif input_file.endswith('.doc'):    
        extension = '-filter pdfimport -close-early'    
    else:    
        raise ValueError('Unsupported file format')    
    
    # 构建命令行参数    
    command = f'libreoffice --headless --convert-to pdf --outdir {os.path.dirname(output_file)} {input_file}{extension}'    
    
    # 运行命令行命令    
    try:  
        subprocess.run(command, shell=True)    
    except subprocess.CalledProcessError as e:  
        print(f"Error occurred while converting the document: {e}")  
        return False  
    
    # 检查输出文件是否存在    
    if not os.path.exists(output_file):    
        raise FileNotFoundError(f'Failed to create {output_file}')    
    
# 使用示例    
input_file = 'path/to/input.docx'  # 替换为实际的输入文件路径    
output_file = 'path/to/output.pdf'  # 替换为实际的输出文件路径    
convert_to_pdf(input_file, output_file)
相关推荐
凌盛羽3 分钟前
在MDK-ARM编译后用python解析map文件在编译窗口输出Flash和RAM使用及剩余情况
arm开发·python·stm32·单片机·mysql·链表·esp32
2301_810154556 分钟前
CVE-2019-6341 漏洞复现
java·开发语言
GuokLiu6 分钟前
260331-OpenWebUI统计所有Chat的对话字符个数
python
哈伦20196 分钟前
Python 生成随机数
python·机器学习·pandas
IT大师兄吖7 分钟前
小红书FireRed-OCR 2B 图片和PDF转md 懒人整合包
pdf·ocr
zzwq.9 分钟前
魔法方法 __init__ 与 __new__ 的区别与使用场景
python
老虎062714 分钟前
数据结构09(Java)-- 二分查找模板
java·开发语言·数据结构
蓝天星空14 分钟前
C#中for循环和foreach循环的区别
开发语言·c#
傻啦嘿哟18 分钟前
如何使用 Python 操作 Excel 图片:插入、提取与压缩
开发语言·python·excel
Dxy123931021618 分钟前
Python 如何反向 `enumerate` 遍历枚举
python