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

相关推荐
yivifu11 小时前
使用PyMuPdf删除PDF文档中的水印
pdf·pymupdf·去水印
ComPDFKit12 小时前
ComPDF的产品升级:从工具包到PDF服务
pdf
占疏15 小时前
pdf文件解析
pdf
开开心心_Every17 小时前
音频视频转文字工具,离线语音识别免费
人工智能·游戏·微信·pdf·excel·语音识别·memcache
开开心心_Every17 小时前
电脑网速加速工具,无线有线叠加网络
网络·游戏·微信·pdf·电脑·excel·语音识别
小沈同学呀17 小时前
SpringBoot 使用Docx4j实现 DOCX 转 PDF
spring boot·后端·pdf·docx4j
开开心心就好17 小时前
免费批量抠图软件大模型,复杂倒影精准去除
网络·windows·pdf·计算机外设·电脑·硬件架构·材料工程
MaiTube&Maipdf2 天前
麦瓜PDF 的安全分享流程图:从上传到权限控制
pdf·流程图
CodeCaptain2 天前
【一】dify的知识库上传过相关的文件作为待引用的文档,这样已经与[原始语料 → 按“一文档一份 PDF”存 ObjectStore]同样的概念吗
人工智能·pdf·dify
放飞自我的Coder2 天前
【PDF拆分 Python拆分左右并排PDF】
python·pdf