今天需要将一个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
变量来控制输出图像的清晰度(每英寸点数)。