Python将图片批量转换成pdf

将 Word 文档中的图片转换为 PDF 并合并的代码。代码首先从指定路径读取 Word 文档中的图片,然后将图片文件保存到指定的文件夹 path_convert 中。接着,程序遍历保存图片的文件夹,将所有图片文件转换为同名的 PDF 文件,并保存到原图片文件所在文件夹中。最后,程序将同一文件夹下的所有 PDF 文件合并成一个名为 output.pdf 的文件。

需要注意的是,在代码中需要安装 PyPDF2 库,因为该库提供了一个 PdfMerger 类,可以用来合并 PDF 文件。如果没有安装该库,可以打开命令提示符或终端,使用下面的命令进行安装:

完整代码:

# -*- coding: utf-8 -*-
"""
Spyder Editor

This is a temporary script file.
"""

from PIL import Image
import os
from os.path import join
from pathlib import Path
from PyPDF2 import PdfMerger


path = "C:/Users/ypzhao/Desktop/word/"
path_convert = "C:/Users/ypzhao/Desktop/pict/"

for i in os.listdir(path):
    file_name,file_suffix = i.split(".")
    if file_suffix != "jpg":
        im = Image.open(path+f"{i}")
        im.save(path_convert+f"{file_name}"+".jpg")       
    else:
        pass   

def convert_to_pdf(file_path):
    # 打开图片文件
    img = Image.open(file_path)
    # 将图片转换为 PDF,并保存到同名文件
    pdf_path = os.path.splitext(file_path)[0] + ".pdf"
    img.save(pdf_path, "PDF", resolution=300.0)

def main():
    # 指定图片所在目录
    image_dir = Path("C:/Users/ypzhao/Desktop/pict/")
    # 遍历目录下的所有文件
    for file_path in image_dir.glob("*"):
        # 如果是图片文件,则转换为 PDF
        if file_path.suffix.lower() in (".jpg", ".jpeg", ".png", ".bmp"):
            convert_to_pdf(file_path)
    # 将所有 PDF 合并成一个文件
    merger = PdfMerger()
    for file_path in image_dir.glob("*.pdf"):
        merger.append(str(file_path))
    merger.write("output.pdf")

if __name__ == "__main__":
    main()

运行结果:
在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

群智能算法小狂人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值