Python 多張圖片合并成一個(gè)pdf的參考示例
拿到一個(gè)需求最重要的就是將大塊任務(wù)拆分成一個(gè)個(gè)小模塊,逐個(gè)擊破。
拍照這一步首先是將所有的書頁拍好,需要注意的是要按照書的頁碼來拍,因?yàn)楹竺娴呐判蚴前凑瘴募M(jìn)行排序的,拍照的文件名基本上是按照時(shí)間生成的,如果拍的時(shí)候亂了,到時(shí)候生成的 pdf 里面的頁碼也會(huì)亂掉。
用到的Python 操作庫Python 最好的地方就是有大量的第三方庫能幫我們快速實(shí)現(xiàn)我們想要的方法,搜索到了兩個(gè)庫, PyFPDF 和img2pdf,我們這里選擇img2pdf來完成我們的需求 pip install img2pdf
Python遍歷文件夾獲取圖片dirname = 'f:/wlzcool' imgs = [] for fname in os.listdir(dirname):if not fname.endswith('.jpg'): continuepath = os.path.join(dirname, fname)if os.path.isdir(path): continueimgs.append(path)
需要注意圖片的文件名如果是純數(shù)字且位數(shù)不一樣,排序會(huì)為1之后是10而不是2,需要進(jìn)行一個(gè)排序,如果是手機(jī)拍的文件就沒有這個(gè)問題。 files.sort(key=lambda x: int(x[:-4]))
旋轉(zhuǎn)圖片展示方向并壓縮像素有的時(shí)候手機(jī)拍出來的圖片是水平的,需要將其改為豎直的用rotate旋轉(zhuǎn)方向的時(shí)候需要注意加上expand=True 這個(gè)參數(shù),否則會(huì)有黑邊出現(xiàn)。
手機(jī)的照片像素太高,有的需要進(jì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 Imageimport osimport img2pdfflag = Falsewhile not flag: dirname = input('請(qǐng)輸入圖片文件夾所在路徑(例如d:/wlzcool):') flag = os.path.exists(dirname) if not flag:print('圖片文件夾所在路徑不存在!')saveflag = Falsewhile not saveflag: savedirname = input('請(qǐng)輸入目標(biāo)圖片文件夾所在路徑(例如d:/wlzcool2):') saveflag = os.path.exists(savedirname) if not saveflag:print('圖片文件夾所在路徑不存在!')automakedir = input('是否自動(dòng)創(chuàng)建對(duì)應(yīng)文件夾?(是Y/否N):')if automakedir.strip().upper() == 'Y': os.makedirs(savedirname) saveflag = Truefiles = os.listdir(dirname)reductionFactor = int(input('請(qǐng)輸入長(zhǎng)寬壓縮比(例如3):'))if reductionFactor <= 0: reductionFactor = 3isConvertBlack = 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('請(qǐng)輸入輸出文件名(例如:第一章):')with open(filename + '.pdf', 'wb') as f: imgs = [] files = os.listdir(savedirname) for fname in files:if not fname.endswith('.jpg'): continuepath = os.path.join(savedirname, fname)if os.path.isdir(path): continueimgs.append(path) f.write(img2pdf.convert(imgs))整體代碼
寫成腳本需要考慮的有很多,為了方便使用,需要將各種參數(shù)改為允許用戶輸入的。比如圖片文件夾所在的路徑,壓縮比之類的
from PIL import Imageimport osimport img2pdfflag = Falsewhile not flag: dirname = input('請(qǐng)輸入圖片文件夾所在路徑(例如d:/wlzcool):') flag = os.path.exists(dirname) if not flag:print('圖片文件夾所在路徑不存在!')saveflag = Falsewhile not saveflag: savedirname = input('請(qǐng)輸入目標(biāo)圖片文件夾所在路徑(例如d:/wlzcool2):') saveflag = os.path.exists(savedirname) if not saveflag:print('圖片文件夾所在路徑不存在!')automakedir = input('是否自動(dòng)創(chuàng)建對(duì)應(yīng)文件夾?(是Y/否N):')if automakedir.strip().upper() == 'Y': os.makedirs(savedirname) saveflag = Truefiles = os.listdir(dirname)reductionFactor = int(input('請(qǐng)輸入長(zhǎng)寬壓縮比(例如3):'))if reductionFactor <= 0: reductionFactor = 3isConvertBlack = 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('請(qǐng)輸入輸出文件名(例如:第一章):')with open(filename + '.pdf', 'wb') as f: imgs = [] files = os.listdir(savedirname) for fname in files:if not fname.endswith('.jpg'): continuepath = os.path.join(savedirname, fname)if os.path.isdir(path): continueimgs.append(path) f.write(img2pdf.convert(imgs))將腳本打包成exe
不是所有的電腦都有Python環(huán)境,我們需要將腳本打包成exe方便在任意一臺(tái)電腦上使用。 使用 PyInstaller 來進(jìn)行腳本的打包
安裝 PyInstallerpip install pyinstaller
打包腳本在腳本所在的路徑的cmd中執(zhí)行以下命令即可
pyinstaller -F yourprogram.py總結(jié)
人生苦短,我用 Python,在強(qiáng)大的第三方庫幫助下,我們只需很少的時(shí)間就可以開發(fā)一個(gè)很有意思的小功能。
以上就是Python 多張圖片合并成一個(gè)pdf的參考示例的詳細(xì)內(nèi)容,更多關(guān)于Python 圖片合并成pdf的資料請(qǐng)關(guān)注好吧啦網(wǎng)其它相關(guān)文章!
相關(guān)文章:
1. PHP循環(huán)與分支知識(shí)點(diǎn)梳理2. ASP刪除img標(biāo)簽的style屬性只保留src的正則函數(shù)3. 前端從瀏覽器的渲染到性能優(yōu)化4. ASP基礎(chǔ)入門第三篇(ASP腳本基礎(chǔ))5. css代碼優(yōu)化的12個(gè)技巧6. ASP實(shí)現(xiàn)加法驗(yàn)證碼7. 無線標(biāo)記語言(WML)基礎(chǔ)之WMLScript 基礎(chǔ)第1/2頁8. 讀大數(shù)據(jù)量的XML文件的讀取問題9. 利用CSS3新特性創(chuàng)建透明邊框三角10. 解析原生JS getComputedStyle
