扫码阅读
手机扫码阅读
合并多图并转为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学习杂记的其他文章
阿里/华为/小米/顺丰/美的等大厂运筹算法岗招聘有哪些要求?
周末整理了一些大厂的运筹优化算法岗位的招聘信息,总结这些职位的核心岗位职责要求分享给大家。
先跑通、再跑对、然后持续优化
自从我回到武汉工作以来,我陆续负责了多个项目,包括配送路线优化和仓网布局选址等。
分享一波学习资料
之前有一些朋友留言想要一些Python学习的资料,最近小编整理了一些资料。
使用tkinter创建登录界面
tkinter简介tkinter是Python的标准GUI(图形用户界面)库,内置在Python自带的模块中。
Python常用内置函数介绍(一)
Python自带了许多内置函数,非常方便对数据变量进行处理,本文介绍一些常用的内置函数。1.set
加入社区微信群
与行业大咖零距离交流学习


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