python将pdf文件转为图片,如果pdf文件包含多页,将转化的多个图片通过垂直或者水平合并成一张图片

要将PDF文件转换为图片,并将多页PDF垂直合并成一张图片,可以使用PyMuPDF(也称为fitz)库来读取PDF文件,并使用Pillow库来处理和合并图片。以下是一个示例代码,展示了如何实现这个功能:

首先,确保已经安装了所需的库。可以使用以下命令来安装它们:

复制代码
pip install PyMuPDF Pillow

然后,可以使用以下Python代码来实现PDF到图片的转换以及图片的垂直或者水平合并:

复制代码
import fitz  # PyMuPDF
from PIL import Image


def pdf_to_img_list(pdf_path):
    # 打开PDF文件
    pdf_document = fitz.open(pdf_path)
    images_list = []

    # 遍历PDF的每一页
    for page_num in range(len(pdf_document)):
        page = pdf_document.load_page(page_num)  # 加载页面
        pix = page.get_pixmap(matrix=fitz.Matrix(2, 2), alpha=False)   # 将页面转换为图片
        img = Image.frombytes("RGB", [pix.width, pix.height], pix.samples)
        images_list.append(img)

    return images_list

"""垂直合并"""
def merge_images_vertically(images, output_path):
    # 获取每张图片的宽度和高度
    widths, heights = zip(*(i.size for i in images))

    # 计算合并后的图片宽度(取最宽的图片宽度)和总高度
    total_width = max(widths)
    total_height = sum(heights)

    # 创建一个新的空白图片,用于存放合并后的图片
    new_image = Image.new('RGB', (total_width, total_height))

    # 将每张图片按顺序粘贴到新的图片上
    y_offset = 0
    for img in images:
        new_image.paste(img, (0, y_offset))
        y_offset += img.height

    # 保存合并后的图片
    new_image.save(output_path)


"""水平合并"""
def merge_images_horizontally(images,output_path):
    # 计算合并后的图像宽度和高度
    widths, heights = zip(*(i.size for i in images))
    total_width = sum(widths)
    max_height = max(heights)

    # 创建一个新的空白图像,用于存放合并后的图像
    new_image = Image.new('RGB', (total_width, max_height))

    x_offset = 0
    for img in images:
        new_image.paste(img, (x_offset, 0))
        x_offset += img.width

    new_image.save(output_path)

"""调用方法,进行合并"""
def pdf_to_image(pdf_path, output_path):
    # pdf转图片
    images = pdf_to_img_list(pdf_path)
    # 垂直合并
    merge_images_vertically(images, output_path)
    # 水平合并
    merge_images_horizontally(images, output_path)


# 使用示例
pdf_file = 'example.pdf'  # 替换为你的PDF文件路径
output_image = 'output_image.jpg'  # 替换为你想要保存的图片路径

pdf_to_image(pdf_file, output_image)
相关推荐
2501_930707782 天前
使用C#代码替换 PDF 文档中的文本
pdf
周末也要写八哥2 天前
Visual C++6.0下载安装流程及PDF学习手册资源
c++·学习·pdf
优化控制仿真模型2 天前
2026初中英语考纲词汇表(1600词)PDF电子版
经验分享·pdf
2401_876964132 天前
27考研优路|肖睿|唐辛|师大集训营|大牙|B站橙啦101公共课PDF
考研·pdf
2401_876964132 天前
27余峰|苏一|大李子|鹿吖101公共课托管班网课PDF
pdf
SEO-狼术2 天前
Visualize Trends with Bar Charts
pdf·.net
私人珍藏库2 天前
【PC】[吾爱大神原创工具] PDFImageViewer V1 永久免费的PDF图像查看和导出工具
windows·pdf·工具·软件·多功能
小饕2 天前
RAG 数据加载全攻略:从文本到 PDF 的 Loader 选型指南
人工智能·pdf
其实秋天的枫2 天前
【26年】考研数学一、二、三历年真题及答案解析PDF电子版(1987-2026年)
经验分享·pdf
夏日清风有你2 天前
WPS pdf 页面替换和编辑使用
pdf