python | 图片转换为 pdf 实现方法

devtools/2024/9/25 2:34:51/

目录

一、PIL 库简介及安装使用方法

python%20%E4%B8%8D%E5%90%8C%E7%89%88%E6%9C%AC%E4%B8%8B%20PIL%20%E7%9A%84%E4%BD%BF%E7%94%A8%E6%96%B9%E6%B3%95-toc" style="margin-left:40px;">(一)python 不同版本下 PIL 的使用方法

pdf%C2%A0%E7%9A%84%E4%B8%A4%E7%A7%8D%E5%AE%9E%E7%8E%B0%E6%96%B9%E6%B3%95-toc" style="margin-left:0px;">二、图片转换为 pdf 的两种实现方法

pdf%20%E9%A1%B5%E9%9D%A2%E5%B0%BA%E5%AF%B8%E8%B7%9F%E9%9A%8F%E5%9B%BE%E7%89%87%E5%A4%A7%E5%B0%8F-toc" style="margin-left:40px;">(一)简易版——pdf 页面尺寸跟随图片大小

pdf%C2%A0%E6%AF%8F%E9%A1%B5%E5%B0%BA%E5%AF%B8%E7%BB%9F%E4%B8%80%E4%B8%BA%20A4-toc" style="margin-left:40px;">(二)常用版——pdf 每页尺寸统一为 A4


一、PIL 库简介及安装使用方法

本文将图片转换为 pdf 的实现方法,主要是基于 python 的第三方图像处理库 PIL。

PIL(Python Imaging Library),免费开源,提供了非常强大的图像处理功能。

PIL,只支持 python 2.x 版本;随着发展, Python 社区开发了一个名为 Pillow 的分支,一个兼容 PIL 的图像处理库,用以支持 python 3.x 版本。

Pillow,不仅继承了 PIL 的功能,还在其基础上增加了许多新的特性,使其成为比原始 PIL 更加活跃的图像处理库。

python%20%E4%B8%8D%E5%90%8C%E7%89%88%E6%9C%AC%E4%B8%8B%20PIL%20%E7%9A%84%E4%BD%BF%E7%94%A8%E6%96%B9%E6%B3%95">(一)python 不同版本下 PIL 的使用方法

(1)python 2.x:通常不需要单独安装,PIL 已包含在标准库中,可直接使用。

(2)python 3.x:需要单独安装 Pillow 库来代替 PIL。

作者使用的是 python 3.x,并直接通过 pip 安装了 Pillow 库。

安装命令如下:

python">pip install Pillow

查看是否安装成功及当前版本:

python">pip show pillow

图片

pdf%C2%A0%E7%9A%84%E4%B8%A4%E7%A7%8D%E5%AE%9E%E7%8E%B0%E6%96%B9%E6%B3%95">二、图片转换为 pdf 的两种实现方法

pdf%20%E9%A1%B5%E9%9D%A2%E5%B0%BA%E5%AF%B8%E8%B7%9F%E9%9A%8F%E5%9B%BE%E7%89%87%E5%A4%A7%E5%B0%8F">(一)简易版——pdf 页面尺寸跟随图片大小

该段代码适用于:

1、将单张或多张图片转换为 pdf

2、目标文件夹中有几张图片,转换后的 pdf 就有多少页。

3、转换后的 pdf 页面默认尺寸设置:视具体情况而定。简单来说,就是转换后的 pdf 页面尺寸会跟随图片大小,这样也就导致 pdf 页面大小不一。

完整代码如下:

python">from PIL import Image as pilImage
import os# 简易版——图片转换为pdfpdf页面随图片大小浮动
def convert_images_to_pdf(image_file):os.chdir(image_file)images = []file_lis = os.listdir(image_file)output_path = 'output.pdf'con = 0for image_path in file_lis:if image_path.endswith(('.jpg', '.png')):image = pilImage.open(image_path)images.append(image.convert("RGB"))con += 1print(image_path + ':第%d张' % con)images[0].save(output_path, save_all=True, append_images=images[1:])print('转换完成,共计%d张图片' % len(images))if __name__ == "__main__":image_file = input(r'输入目标图片所在文件夹路径(如E:\test):')convert_images_to_pdf(image_file)

测试结果—页面随图片大小

图片

图片

注:本段代码只涵盖了常见的 jpg、png 两种图片格式,其他格式可以直接在代码中追加。

图片

pdf%C2%A0%E6%AF%8F%E9%A1%B5%E5%B0%BA%E5%AF%B8%E7%BB%9F%E4%B8%80%E4%B8%BA%20A4">(二)常用版——pdf 每页尺寸统一为 A4

基于(一)中的代码,引入了第三方模块 reportlab,对转换后的 pdf 页面尺寸进行设置。

1、第一步,先通过命令:pip show reportlab ,查看是否已经安装有 reportlab 模块,已安装的情况下会提示版本号等信息,并且在使用时不会报错。

如果没有安装 reportlab 模块,则需要进行安装:pip install reportlab。

注:经作者实测,直接使用 pip 命令安装可能会失败,因每台电脑所装的 python 版本、环境依赖等,失败情况可能也有所不同。解决办法:先去下载对应自身 python 版本的 reportlab 包或 whl 文件,再进行安装。常用下载链接可参考: https://pypi.org/search/?q=reportlab。

2、第二步,安装好所需要的库后,直接复制并运行下面的代码,输入需要转换的图片文件夹路径即可。

该段代码适用于:

1、将单张或多张图片转换为 pdf

2、目标文件夹中有几张图片,转换后的 pdf 就有多少页。

3、转换后的 pdf 每页大小均为 A4 。

完整代码如下:

python">from PIL import Image as pilImage
from reportlab.platypus import SimpleDocTemplate, Image, PageBreak
from reportlab.lib.pagesizes import A4, landscape
import os# 获取目标文件下图片文件
def get_Images(image_file):images = []file_lis = os.listdir(image_file)for image_path in file_lis:if image_path.endswith(('jpg', 'png')):images.append(image_path)return images, image_file# 常用版——图片转换为pdf,限制pdf页面大小为A4
def convert_images_to_pdfp(images, image_file):os.chdir(image_file)# 获取A4尺寸a4_w, a4_h = landscape(A4)# 创建一个PDF文档pdf_doc = SimpleDocTemplate(r'tmp.pdf')if len(images) == 0:print('该文件夹路径下无图片,请检查图片格式!')elif len(images) == 1:# 获取图片尺寸img = pilImage.open(images[0])img_w, img_h = img.size# 设置合适的缩放比率ratio = min(a4_w / img_w, a4_h / img_h)# 创建文档page = Image(images[0], img_w * ratio, img_h * ratio)pdf_doc.build([page])print(images[0] + '——转换完成')else:frames = []  # 用于存储多张图片框架con = 0for image in images:# 获取图片尺寸img = pilImage.open(image)img_w, img_h = img.size# 设置合适的缩放比率ratio = min(a4_w / img_w, a4_h / img_h)# 储存文档内容page = Image(image, img_w * ratio, img_h * ratio)frames.append(page)  # 将文档内容添加到列表中frames.append(PageBreak())  # 在每张图片后添加PageBreakcon += 1print(image + '——第%d张' % con)pdf_doc.build(frames)print('转换完成,共计%d张' % len(images))if __name__ == "__main__":image_file = input(r'输入目标图片所在文件夹路径(如E:\test):')images = get_Images(image_file)convert_images_to_pdfp(images[0], images[1])

测试结果——每页均为 A4 大小

图片

图片

注:本段代码只涵盖了常见的 jpg、png 两种图片格式,其他格式可以直接在代码中追加即可。

总结:图片的大小是转换后的 pdf 是否清晰、符合要求的重要因素。代码(二)中对图片进行了简单缩放,可以根据自身需求在代码中对图片大小进行调整。(如果对代码不是很熟悉,有一招简单方法,就是转换之前,可以先P图)。

以上就是基于 python 第三方库 PIL、reportlab ,将图片转换为pdf的方法,可供参考。


http://www.ppmy.cn/devtools/99702.html

相关文章

Linux常用指令大全

一、文件和目录管理 指令功能注释ls列出目录内容列出当前目录或指定目录下的文件和子目录cd切换目录切换当前工作目录pwd显示当前目录显示当前工作目录的完整路径mkdir创建目录创建一个新的目录rmdir删除空目录删除一个空的目录rm删除文件或目录删除文件或目录,-r选…

Java迭代器(Iterator)和分割器(Spliterator)

在Java中,迭代器(Iterator)和分割器(Spliterator)都是用于遍历集合(Collection)的高级机制,但它们在设计目的和使用场景上有所不同。 迭代器(Iterator) 迭代…

微服务的负载均衡不同的场景应用

这些负载均衡策略各有不同的优点和应用场景。以下是每种负载均衡策略的详细解释及其适用场景: 1. Random Load Balance(随机算法) 描述: 随机算法通过随机选择一个服务器来处理请求。对于性能较好的服务器,可以设置更大的权重值…

node版本8.x→16.x,前端维护火葬场,问题及解决方案总结

为了后续的工程开发,我需要升级我的node,在此之前我的node版本是8,这个版本太老了,从8升级到16的跨度太大,对于以前的许多项目,产生了非常多维护方面的问题,历时四天终于全部解决了,…

C++ | Leetcode C++题解之第355题设计推特

题目&#xff1a; 题解&#xff1a; class Twitter {struct Node {// 哈希表存储关注人的 Idunordered_set<int> followee;// 用链表存储 tweetIdlist<int> tweet;};// getNewsFeed 检索的推文的上限以及 tweetId 的时间戳int recentMax, time;// tweetId 对应发送…

SpringBean

1. 什么是Spring Bean 定义: Spring Bean是由Spring IoC容器管理的对象。是应用程序的核心组成部分&#xff0c;通常是服务、DAO、控制器等。 2. Bean的定义方式 XML配置: 通过XML文件定义Bean。 <beans xmlns"http://www.springframework.org/schema/beans"x…

Swift 中的影像魔术:Core Video 的高级应用

标题&#xff1a;Swift 中的影像魔术&#xff1a;Core Video 的高级应用 在 Swift 开发中&#xff0c;Core Video 是 Apple 提供的一个强大的框架&#xff0c;用于处理高质量的视频内容。从实时视频滤镜到高级图像处理&#xff0c;Core Video 为开发者提供了丰富的 API 来实现…

链动 2+1 模式小程序 AI 智能名片商城源码培训邀约策略研究

摘要&#xff1a;本文深入剖析链动 21 模式小程序 AI 智能名片商城源码的培训邀约策略&#xff0c;从该源码的价值出发&#xff0c;阐述邀约的重要性&#xff0c;并详细介绍具体的邀约策略&#xff0c;旨在为相关培训活动提供切实可行的指导&#xff0c;提高邀约成功率&#xf…