扫码阅读
手机扫码阅读
合并多图并转为PDF文件

我们非常重视原创文章,为尊重知识产权并避免潜在的版权问题,我们在此提供文章的摘要供您初步了解。如果您想要查阅更为详尽的内容,访问作者的公众号页面获取完整文章。


Python学习杂记
扫码关注公众号
在一次为企业处理大量零碎发票的任务中,为了便于打印存档,采取了一系列措施将数百张发票照片处理成单个PDF文件。首先,使用苹果手机拍摄的照片需要筛选出JPG文件并降低其分辨率,以便合并成PDF文件。随后,通过编写代码,将这些图片合并成一个PDF,最后将所有的JPG文件移动到一个新的文件夹以方便存档。
首先,由于拍摄的照片文件较大,需要筛选出文件夹中的JPG文件并减小其分辨率。通过Python代码实现,选中所有JPG文件并将其分辨率降低到约300KB大小,以便于合并。此过程耗时17秒。
from PIL import Image
import glob, os
for files in glob.glob(r'D:\发票\fp\*.JPG'):
filepath,filename = os.path.split(files)
filterame,exts = os.path.splitext(filename)
opfile = r"D:\发票\cs" #输出路径
im = Image.open(files)
w,h = im.size
im_ss = im.resize((int(w*0.5), int(h*0.5)))
im_ss.save(opfile+"\\"+ filterame+'.JPG') #注意路径要双斜杠或者反斜杠
接下来,定义了一个函数,用于把减小分辨率后的JPG图片合并成一个PDF文件。通过调用这个函数,只需指定输入和输出路径即可完成合并。这个过程耗时29秒。
from fpdf import FPDF
from PIL import Image
import os
def makePdf(pdfFileName, listPages, dizhi):
cover = Image.open(dizhi+ listPages[0])
width, height = cover.size
pdf = FPDF(unit = "pt", format = [width, height])
for page in listPages:
pdf.add_page()
pdf.image(dizhi+page, 0, 0)
pdf.output(pdfFileName, "F")
最后,为了方便存档,编写代码将所有JPG文件移动到一个新的文件夹中。这个简单的文件操作标志着任务的完成。
import os
import glob
import shutil
path = r'D:\发票\fp' #原始文件路径
path_new = r'D:\发票\fl' #目标文件路径
list_name = os.listdir(path)
print(list_name)
print(len(list_name))
for f in os.listdir(path):
filename = os.path.join(path, f)
if f.split(".")[-1] == "JPG":
print(f)
shutil.move(filename, path_new)
print("done")
想要了解更多内容?


Python学习杂记
扫码关注公众号
Python学习杂记的其他文章
cp-sat求解器介绍及使用案例
ortools是Google开发的一套优化工具,其中ortools中自带的cp-sat是一个用于求解约束规划的求解器。
一份超全Python代码汇总备忘清单
今天,我给大家分享一份我在GitHub上搜集的Python编程代码汇总备忘清单。
Python的面板绘图库turtle的介绍和使用
Turtle库是Python中一个非常有趣的模块,它允许用户使用面向对象的编程方式创建和控制一个简单的图形窗口。
or-tools解决排程问题
or-tools是谷歌AI系列的运筹优化系列的包,里面提供了很多不错的优化工具。从官网上看,or-tools能解决的问题主要有线性优化、整数优化、路由(车辆运输问题)、装修、调度(排程、工作分配)等问题。
一文了解Python中全局变量和局部变量
在Python编程中,变量的作用域是一个重要的概念,它决定了变量在程序中的可见性和生命周期。
加入社区微信群
与行业大咖零距离交流学习


PMO实践白皮书
白皮书上线
白皮书上线