拿到一個需求最重要的就是將大塊任務拆分成一個個小模塊,逐個擊破。
這一步首先是將所有的書頁拍好,需要注意的是要按照書的頁碼來拍,因為后面的排序是按照文件名進行排序的,拍照的文件名基本上是按照時間生成的,如果拍的時候亂了,到時候生成的 pdf 里面的頁碼也會亂掉。
Python 最好的地方就是有大量的第三方庫能幫我們快速實現(xiàn)我們想要的方法,搜索到了兩個庫, PyFPDF 和img2pdf,我們這里選擇img2pdf來完成我們的需求 pip install img2pdf
dirname = "f:/wlzcool" imgs = [] for fname in os.listdir(dirname): if not fname.endswith(".jpg"): continue path = os.path.join(dirname, fname) if os.path.isdir(path): continue imgs.append(path)
需要注意圖片的文件名如果是純數(shù)字且位數(shù)不一樣,排序會為1之后是10而不是2,需要進行一個排序,如果是手機拍的文件就沒有這個問題。 files.sort(key=lambda x: int(x[:-4]))
有的時候手機拍出來的圖片是水平的,需要將其改為豎直的
用rotate旋轉方向的時候需要注意加上expand=True 這個參數(shù),否則會有黑邊出現(xiàn)。
手機的照片像素太高,有的需要進行壓縮以保證最后生成的pdf的大小適中。
img = Image.open(path) if img.size[0] > img.size[1]: im_rotate = img.rotate(90, expand=True) size = (int(im_rotate.size[0] / 3), int(im_rotate.size[1] / 3)) im_rotate = im_rotate.resize(size) im_rotate.save(savepath, quality=95) else: size = (int(img.size[0] / 3), int(img.size[1] / 3)) img = img.resize(size) img.save(savepath, quality=95)
寫成腳本需要考慮的有很多,為了方便使用,需要將各種參數(shù)改為允許用戶輸入的。比如圖片文件夾所在的路徑,壓縮比之類的
from PIL import Image import os import img2pdf flag = False while not flag: dirname = input("請輸入圖片文件夾所在路徑(例如d:/wlzcool):") flag = os.path.exists(dirname) if not flag: print("圖片文件夾所在路徑不存在!") saveflag = False while not saveflag: savedirname = input("請輸入目標圖片文件夾所在路徑(例如d:/wlzcool2):") saveflag = os.path.exists(savedirname) if not saveflag: print("圖片文件夾所在路徑不存在!") automakedir = input("是否自動創(chuàng)建對應文件夾?(是Y/否N):") if automakedir.strip().upper() == "Y": os.makedirs(savedirname) saveflag = True files = os.listdir(dirname) reductionFactor = int(input("請輸入長寬壓縮比(例如3):")) if reductionFactor = 0: reductionFactor = 3 isConvertBlack = input("是否輸出黑白版本?(是Y/否N):").strip().upper() == "Y" for fname in files: if not fname.endswith(".jpg"): continue path = os.path.join(dirname, fname) savePath = os.path.join(savedirname, fname) if os.path.isdir(path): continue img = Image.open(path) if img.size[0] > img.size[1]: im_rotate = img.rotate(90, expand=True) size = (int(im_rotate.size[0] / reductionFactor), int(im_rotate.size[1] / reductionFactor)) im_rotate = im_rotate.resize(size) if isConvertBlack: im_rotate = im_rotate.convert("L") im_rotate.save(savePath, quality=95) else: size = (int(img.size[0] / reductionFactor), int(img.size[1] / reductionFactor)) img = img.resize(size) if isConvertBlack: img = img.convert("L") img.save(savePath, quality=95) filename = input("請輸入輸出文件名(例如:第一章):") with open(filename + ".pdf", "wb") as f: imgs = [] files = os.listdir(savedirname) for fname in files: if not fname.endswith(".jpg"): continue path = os.path.join(savedirname, fname) if os.path.isdir(path): continue imgs.append(path) f.write(img2pdf.convert(imgs))
寫成腳本需要考慮的有很多,為了方便使用,需要將各種參數(shù)改為允許用戶輸入的。比如圖片文件夾所在的路徑,壓縮比之類的
from PIL import Image import os import img2pdf flag = False while not flag: dirname = input("請輸入圖片文件夾所在路徑(例如d:/wlzcool):") flag = os.path.exists(dirname) if not flag: print("圖片文件夾所在路徑不存在!") saveflag = False while not saveflag: savedirname = input("請輸入目標圖片文件夾所在路徑(例如d:/wlzcool2):") saveflag = os.path.exists(savedirname) if not saveflag: print("圖片文件夾所在路徑不存在!") automakedir = input("是否自動創(chuàng)建對應文件夾?(是Y/否N):") if automakedir.strip().upper() == "Y": os.makedirs(savedirname) saveflag = True files = os.listdir(dirname) reductionFactor = int(input("請輸入長寬壓縮比(例如3):")) if reductionFactor = 0: reductionFactor = 3 isConvertBlack = input("是否輸出黑白版本?(是Y/否N):").strip().upper() == "Y" for fname in files: if not fname.endswith(".jpg"): continue path = os.path.join(dirname, fname) savePath = os.path.join(savedirname, fname) if os.path.isdir(path): continue img = Image.open(path) if img.size[0] > img.size[1]: im_rotate = img.rotate(90, expand=True) size = (int(im_rotate.size[0] / reductionFactor), int(im_rotate.size[1] / reductionFactor)) im_rotate = im_rotate.resize(size) if isConvertBlack: im_rotate = im_rotate.convert("L") im_rotate.save(savePath, quality=95) else: size = (int(img.size[0] / reductionFactor), int(img.size[1] / reductionFactor)) img = img.resize(size) if isConvertBlack: img = img.convert("L") img.save(savePath, quality=95) filename = input("請輸入輸出文件名(例如:第一章):") with open(filename + ".pdf", "wb") as f: imgs = [] files = os.listdir(savedirname) for fname in files: if not fname.endswith(".jpg"): continue path = os.path.join(savedirname, fname) if os.path.isdir(path): continue imgs.append(path) f.write(img2pdf.convert(imgs))
不是所有的電腦都有Python環(huán)境,我們需要將腳本打包成exe方便在任意一臺電腦上使用。 使用 PyInstaller 來進行腳本的打包
pip install pyinstaller
在腳本所在的路徑的cmd中執(zhí)行以下命令即可
pyinstaller -F yourprogram.py
人生苦短,我用 Python,在強大的第三方庫幫助下,我們只需很少的時間就可以開發(fā)一個很有意思的小功能。
以上就是Python 多張圖片合并成一個pdf的參考示例的詳細內(nèi)容,更多關于Python 圖片合并成pdf的資料請關注腳本之家其它相關文章!