扫码阅读
手机扫码阅读
合并多图并转为PDF文件
38 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学习杂记的其他文章
知乎II去北上广深,还是去二线工作?
现在无论是计算机、金融,还是其他热门行业,都可能面临裁员的风险,各行各业就业压力极大,很多一线大厂开始裁员了。
组建国家数据局,加快数字领域建设。
2023年3月7日,国务院机构改革方案中提出组建国家数据局,负责协调推进数据基础制度建设,
马斯克起诉OpenAI,OpenAI强烈反对该诉讼
3月2日,美国加利福尼亚州旧金山高等法院公布了一份诉讼公告。
谷歌gemma:先进的轻量级开源大模型
2月21日,谷歌宣布正式发布了一款名为Gemma的开源大模型。而令人吃惊的是,这一发布距离谷歌上一次发布大模型Gemini1.5还不到一周时间。
Pandas筛选数据的20种方法
Pandas 是一个功能全面的数据科学库,可用于数据清洗、处理和分析。
加入社区微信群
与行业大咖零距离交流学习
软件研发质量管理体系建设
白皮书上线