Python实现批量将图片转为PDF文件的示例代码

Sitin涛哥 2024-12-21 10:45:49编程技术
781

在日常工作中,我们经常需要将多张图片转换为PDF文件,以便于分享和存档。手动操作不仅耗时,而且容易出错。幸运的是,Python 提供了强大的库,如Pillow和PyPDF2,可以帮助我们轻松实现这一任务。本文将详细介绍如何使用Python批量将图片转换为PDF文件,并提供完整的示例代码,帮助读者快速上手。

python.webp

准备工作

在开始之前,需要确保已经安装了所需的Python库。将使用Pillow库来处理图像,并使用PyPDF2库来生成PDF文件。

安装Pillow和PyPDF2

可以使用pip命令来安装这些库:

pip install Pillow PyPDF2

使用Pillow将图片转换为PDF

Pillow是Python Imaging Library(PIL)的一个分支,是一个非常强大的图像处理库。它支持打开、操作和保存多种格式的图像。

单张图片转换为PDF

首先,来看如何将单张图片转换为PDF。

from PIL import Image

def image_to_pdf(image_path, output_path):
    image = Image.open(image_path)
    pdf_path = output_path
    image.convert('RGB').save(pdf_path)
    print(f"已将图片 {image_path} 转换为 PDF 文件 {pdf_path}")

# 示例
image_to_pdf('example.jpg', 'output.pdf')

在这个示例中,打开了一张图片并将其转换为RGB模式,然后保存为PDF文件。

多张图片转换为PDF

接下来,将多张图片合并到一个PDF文件中。

from PIL import Image

def images_to_pdf(image_paths, output_path):
    images = [Image.open(image).convert('RGB') for image in image_paths]
    images[0].save(output_path, save_all=True, append_images=images[1:])
    print(f"已将多张图片合并为 PDF 文件 {output_path}")

# 示例
image_paths = ['image1.jpg', 'image2.jpg', 'image3.jpg']
images_to_pdf(image_paths, 'merged_output.pdf')

在这个示例中,首先将所有图片转换为RGB模式,然后使用save_all=True选项将它们保存为一个PDF文件。

批量处理文件夹中的图片

在实际应用中,可能需要将一个文件夹中的所有图片批量转换为PDF。可以使用os库来遍历文件夹中的所有图片。

import os
from PIL import Image

def folder_to_pdf(folder_path, output_path):
    image_paths = []
    for file_name in os.listdir(folder_path):
        if file_name.endswith(('jpg', 'jpeg', 'png')):
            image_paths.append(os.path.join(folder_path, file_name))
    
    if image_paths:
        images = [Image.open(image).convert('RGB') for image in sorted(image_paths)]
        images[0].save(output_path, save_all=True, append_images=images[1:])
        print(f"已将文件夹 {folder_path} 中的图片合并为 PDF 文件 {output_path}")
    else:
        print("文件夹中没有找到图片文件")

# 示例
folder_to_pdf('images_folder', 'output_folder.pdf')

在这个示例中,遍历指定文件夹中的所有图片,并将它们合并为一个PDF文件。

处理不同格式的图片

有时,需要处理不同格式的图片,如PNG、BMP等。Pillow支持多种图像格式,可以轻松处理这些图片。

import os
from PIL import Image

def folder_to_pdf(folder_path, output_path):
    image_paths = []
    for file_name in os.listdir(folder_path):
        if file_name.endswith(('jpg', 'jpeg', 'png', 'bmp', 'tiff')):
            image_paths.append(os.path.join(folder_path, file_name))
    
    if image_paths:
        images = [Image.open(image).convert('RGB') for image in sorted(image_paths)]
        images[0].save(output_path, save_all=True, append_images=images[1:])
        print(f"已将文件夹 {folder_path} 中的图片合并为 PDF 文件 {output_path}")
    else:
        print("文件夹中没有找到图片文件")

# 示例
folder_to_pdf('images_folder', 'output_folder.pdf')

添加图像压缩和调整

在处理大量图片时,可能需要对图片进行压缩或调整大小,以减少PDF文件的大小。

import os
from PIL import Image

def resize_image(image, max_size):
    ratio = min(max_size / image.width, max_size / image.height)
    new_width = int(image.width * ratio)
    new_height = int(image.height * ratio)
    return image.resize((new_width, new_height), Image.ANTIALIAS)

def folder_to_pdf(folder_path, output_path, max_size=1000):
    image_paths = []
    for file_name in os.listdir(folder_path):
        if file_name.endswith(('jpg', 'jpeg', 'png', 'bmp', 'tiff')):
            image_paths.append(os.path.join(folder_path, file_name))
    
    if image_paths:
        images = [resize_image(Image.open(image).convert('RGB'), max_size) for image in sorted(image_paths)]
        images[0].save(output_path, save_all=True, append_images=images[1:])
        print(f"已将文件夹 {folder_path} 中的图片合并为 PDF 文件 {output_path}")
    else:
        print("文件夹中没有找到图片文件")

# 示例
folder_to_pdf('images_folder', 'output_folder.pdf')

在这个示例中,添加了一个resize_image函数,用于将图片调整到指定大小以内。

完整示例

下面是一个完整的示例代码,将所有步骤综合在一起,实现图片批量转换为PDF的功能。

import os
from PIL import Image

def resize_image(image, max_size):
    ratio = min(max_size / image.width, max_size / image.height)
    new_width = int(image.width * ratio)
    new_height = int(image.height * ratio)
    return image.resize((new_width, new_height), Image.ANTIALIAS)

def folder_to_pdf(folder_path, output_path, max_size=1000):
    image_paths = []
    for file_name in os.listdir(folder_path):
        if file_name.endswith(('jpg', 'jpeg', 'png', 'bmp', 'tiff')):
            image_paths.append(os.path.join(folder_path, file_name))
    
    if image_paths:
        images = [resize_image(Image.open(image).convert('RGB'), max_size) for image in sorted(image_paths)]
        images[0].save(output_path, save_all=True, append_images=images[1:])
        print(f"已将文件夹 {folder_path} 中的图片合并为 PDF 文件 {output_path}")
    else:
        print("文件夹中没有找到图片文件")

# 示例
folder_to_pdf('images_folder', 'output_folder.pdf')

总结

通过本文的介绍,我们了解了如何使用Python中的Pillow和PyPDF2库将多张图片批量转换为PDF文件。从单张图片的转换到多张图片的合并,再到批量处理文件夹中的所有图片,每一步都详细讲解并提供了相应的代码示例。此外,我们还讨论了如何处理不同格式的图片以及如何对图片进行压缩和调整大小,以减少生成的PDF文件的大小。希望本文的内容能够帮助读者高效地完成图片到PDF的转换任务,提高工作效率。

Python 图片转pdf
THE END
蜜芽
故事不长,也不难讲,四字概括,毫无意义。

相关推荐

Python yield 用法大全:轻松掌握生成器与迭代器设计
在Python中,yield关键字是构建生成器的核心工具,它通过状态保存机制实现了高效的内存管理和惰性计算。与传统的迭代器实现相比,yield能将迭代器设计从复杂的类定义简化为直...
2025-09-15 编程技术
532

基于Python的旅游数据分析可视化系统【2026最新】
本研究成功开发了基于Python+Django+Vue+MySQL的旅游数据分析可视化系统,实现了从数据采集到可视化展示的全流程管理。系统采用前后端分离架构,前端通过Vue框架构建响应式界...
2025-09-13 编程技术
559

手把手教你用Python读取txt文件:从基础到实战的完整教程
Python作为数据处理的利器,文件读写是其基础核心功能。掌握txt文件读取不仅能处理日志、配置文件等常见场景,更是理解Python文件I/O的基石。本文ZHANID工具网将从基础语法到...
2025-09-12 编程技术
535

Python Flask 入门指南:从零开始搭建你的第一个 Web 应用
Flask作为 Python 中最轻量级且灵活的 Web 框架之一,特别适合初学者快速上手 Web 应用开发。本文将带你一步步了解如何在本地环境中安装 Flask、创建一个简单的 Web 应用,并...
2025-09-11 编程技术
523

Python 如何调用 MediaPipe?详细安装与使用指南
MediaPipe 是 Google 开发的跨平台机器学习框架,支持实时处理视觉、音频和文本数据。本文脚本之家将系统讲解 Python 环境下 MediaPipe 的安装、配置及核心功能调用方法,涵盖...
2025-09-10 编程技术
570

基于Python开发一个利率计算器的思路及示例代码
利率计算是金融领域的基础需求,涵盖贷款利息、存款收益、投资回报等场景。传统计算依赖手工公式或Excel表格,存在效率低、易出错等问题。Python凭借其简洁的语法和强大的数学...
2025-09-09 编程技术
505