python批量插入图片到一个pdf中

import os
from PIL import Image
from PyPDF2 import PdfFileMerger

# 防止字符串乱码
os.environ['NLS_LANG'] = 'SIMPLIFIED CHINESE_CHINA.UTF8'

class AllImagesToPdf:

    def __init__(self):
        self.imgs_path = "imgs"  # 将所有的图片放到此文件夹中
        self.pdfs_path = "pdfs"  # 将所有转换后的pdf放到此文件夹

    def imgs_to_pdfs(self):
        imgs_path = self.imgs_path
        imgs_list = os.listdir(imgs_path)
        for img_name in imgs_list:
            if "jpg" in img_name or "png" in img_name:
                read_img_path = os.path.join(self.imgs_path,img_name)
                obj_img = Image.open(read_img_path)  # 打开指定路径下的图片
                save_img_path = os.path.join(self.pdfs_path,img_name.split(".")[0]+".pdf")  # 拼接pdf的路径和名称
                obj_img.save(save_img_path)  # 保存为pdf

    def pdfs_to_pdf(self):
        pdfs_path = self.pdfs_path
        pdfs_list = os.listdir(pdfs_path)
        pdfs_path_list = []
        for pdf_name in pdfs_list:
            if pdf_name.endswith(".pdf"):
                pdfs_path_list.append(os.path.join(self.pdfs_path,pdf_name))
        # print(pdfs_path_list)
        pdf_merger = PdfFileMerger()  # 创建PdfFileMerger对象,用来合并pdf文件
        for file_path in pdfs_path_list:
            pdf_merger.append(file_path)

        pdf_merger.write("mergerd.pdf")  # 使用write方法将所有pdf文件写入到一个文件

    def run(self):

        self.imgs_to_pdfs()  # 把大量的图片一个个转为pdf
        print("批量图片转批量pdf完毕")
        self.pdfs_to_pdf()   # 把大量的pdf合并到一个pdf
        print("批量pdf转pdf完毕")


if __name__ == '__main__':
    itp = AllImagesToPdf()
    itp.run()

————————————————

原文链接:https://blog.csdn.net/weixin_44346972/article/details/127263455

posted @   panlifeng  阅读(405)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· Obsidian + DeepSeek:免费 AI 助力你的知识管理,让你的笔记飞起来!
· 分享4款.NET开源、免费、实用的商城系统
· 解决跨域问题的这6种方案,真香!
· 一套基于 Material Design 规范实现的 Blazor 和 Razor 通用组件库
· 5. Nginx 负载均衡配置案例(附有详细截图说明++)
点击右上角即可分享
微信分享提示