扫码阅读
手机扫码阅读
合并多图并转为PDF文件
123 2024-10-28
我们非常重视原创文章,为尊重知识产权并避免潜在的版权问题,我们在此提供文章的摘要供您初步了解。如果您想要查阅更为详尽的内容,访问作者的公众号页面获取完整文章。
查看原文:合并多图并转为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")
想要了解更多内容?
查看原文:合并多图并转为PDF文件
文章来源:
Python学习杂记
扫码关注公众号
Python学习杂记的其他文章
介绍几款实用的AI搜索引擎
在日常生活中,我们大多使用的搜索引擎是百度和谷歌等。本文将给大家简单介绍几款实用的AI助手搜索工具,与传统搜索引擎相比,它们利用人工智能提升了用户体验。
Python 中的正反斜杠用法详解
在Python编程中,字符串是一个常用的数据类型,字符串中的斜杠(反斜杠\x5c和正斜杠/)具有特殊的用法和意义。
知名IT网站博客园再次陷入困境
今天在搜集资料的时候,不经意打开博客园的一则置顶求救帖子(由博客园官方发布)。最近博客园再次发布了求救信,进一步证实了其经营困境的严重性。
运筹优化库PyMathProg使用介绍
PyMathProg是Python里的一个优化求解工具。
Python中的with语句:优化上下文资源管理
在 Python中,with语句是一种用于管理资源的方式。它提供了一种自动处理资源释放的机制,确保在代码块执行完后,相关的资源得到清理。
加入社区微信群
与行业大咖零距离交流学习
SAFe6.0与CMMI3.0映射
白皮书上线
白皮书上线