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)
相关推荐
百事牛科技7 天前
保护文档安全:PDF限制功能详解与实操
windows·pdf
开开心心就好7 天前
安卓开源应用,超时提醒紧急人护独居安全
windows·决策树·计算机视觉·pdf·计算机外设·excel·动态规划
Felicia-侧听8 天前
如何统一PDF页面宽度?统一pdf宽度的2种方法
pdf·pdf宽度统一
开开心心_Every8 天前
音频格式互转工具,支持Mp3ApeWavFlac互转
linux·运维·服务器·typescript·edge·pdf·asp.net
2501_930707788 天前
如何使用C#代码从 PDF 中提取表格并另存为Excel文件
pdf·excel
悟乙己8 天前
实施手册:如何自己构建财务PDF文件内容抽取引擎
pdf
xin_yao_xin8 天前
PDF 转 图片(python)
python·pdf
汤姆百宝箱9 天前
2026新版教材电子课本1-9年级新教材PDF(完整电子版下载)
pdf·小学课本·初中课本·电子教材·电子课本·2026新教材·2026新课本
开开心心就好9 天前
内存清理软件灵活设置,自动阈值快捷键清
运维·服务器·windows·pdf·harmonyos·risc-v·1024程序员节
海兰9 天前
【接上篇】多格式文档支持扩展方案(PDF_Word_Excel)
pdf·word·excel