无需付费开会员,一个Python程序实现PDF转高清图片

今天需要将一个PDF导出为图片,但是一般的在线转换网站导出的图片清晰度都不高,分辨率只有1241*1754,这就导致输出的图片放大后字体是有点模糊的,所以就想到了使用Python中的PyPDF2库来处理PDF文件,以及Pillow库来处理图像

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

复制代码
pip install PyPDF2 Pillow

接下来,可以使用以下Python程序来执行PDF到图片的转换:

复制代码
import fitz
from PIL import Image

# 读取PDF文件
pdf_file = "your_pdf_file.pdf"

# 打开PDF文件
pdf_document = fitz.open(pdf_file)

# 自定义输出图片的清晰度(dpi)
dpi = 300

# 逐页将PDF转换为图像
for page_num in range(pdf_document.page_count):
    page = pdf_document.load_page(page_num)
    
    # 将PDF页面转换为PIL图像
    image = page.get_pixmap(matrix=fitz.Matrix(dpi/72, dpi/72))
    
    # 创建PIL图像对象
    pil_image = Image.frombytes("RGB", [image.width, image.height], image.samples)
    
    # 保存图像为文件
    image_file = f"output_page_{page_num+1}.png"
    pil_image.save(image_file, dpi=(dpi, dpi))

print(f"{pdf_document.page_count} 页PDF已转换为图像。")

将上述代码中的your_pdf_file.pdf替换为你要处理的PDF文件的路径。程序将为每一页生成一个单独的PNG图像文件,你可以自定义dpi变量来控制输出图像的清晰度(每英寸点数)。

相关推荐
Java面试题总结7 小时前
基于 Java 的 PDF 文本水印实现方案(iText7 示例)
java·python·pdf
傻啦嘿哟9 小时前
Python操作PDF页面详解:删除指定页的完整方案
开发语言·python·pdf
m5655bj17 小时前
使用 C# 修改 PDF 页面尺寸
java·pdf·c#
geovindu18 小时前
python: 简单提取PDF文档内文字
开发语言·python·pdf
m0_6948455718 小时前
HandBrake 是什么?视频转码工具使用与服务器部署教程
服务器·前端·pdf·开源·github·音视频
yivifu1 天前
使用PyMuPdf删除PDF文档中的水印
pdf·pymupdf·去水印
ComPDFKit2 天前
ComPDF的产品升级:从工具包到PDF服务
pdf
占疏2 天前
pdf文件解析
pdf
开开心心_Every2 天前
音频视频转文字工具,离线语音识别免费
人工智能·游戏·微信·pdf·excel·语音识别·memcache
开开心心_Every2 天前
电脑网速加速工具,无线有线叠加网络
网络·游戏·微信·pdf·电脑·excel·语音识别