无需付费开会员,一个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变量来控制输出图像的清晰度(每英寸点数)。

相关推荐
zhy8103022 小时前
.net6 使用 FreeSpire.XLS 实现 excel 转 pdf - docker 部署
pdf·.net·excel
慧都小妮子3 小时前
Spire.PDF for .NET【页面设置】演示:打开 PDF 时自动显示书签或缩略图
java·pdf·.net
join86 小时前
解决vue-pdf的签章不显示问题
javascript·vue.js·pdf
小行星1256 小时前
前端把dom页面转为pdf文件下载和弹窗预览
前端·javascript·vue.js·pdf
穆友航20 小时前
PDF内容提取,MinerU使用
数据分析·pdf
拾荒的小海螺2 天前
JAVA:探索 PDF 文字提取的技术指南
java·开发语言·pdf
村东头老张2 天前
Java 实现PDF添加水印
java·开发语言·pdf
好美啊啊啊啊!2 天前
Thymeleaf模板引擎生成的html字符串转换成pdf
pdf·html
zhentiya2 天前
曼昆《经济学原理》第八版课后答案及英文版PDF
大数据·pdf
三天不学习2 天前
如何解决pdf.js跨域从url动态加载pdf文档
javascript·pdf