亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

Python 多張圖片合并成一個pdf的參考示例

瀏覽:101日期:2022-06-15 18:26:49
目錄過程拍照用到的Python 操作庫Python遍歷文件夾獲取圖片旋轉圖片展示方向并壓縮像素整體代碼整體代碼將腳本打包成exe安裝 PyInstaller打包腳本總結過程

拿到一個需求最重要的就是將大塊任務拆分成一個個小模塊,逐個擊破。

拍照

這一步首先是將所有的書頁拍好,需要注意的是要按照書的頁碼來拍,因為后面的排序是按照文件名進行排序的,拍照的文件名基本上是按照時間生成的,如果拍的時候亂了,到時候生成的 pdf 里面的頁碼也會亂掉。

用到的Python 操作庫

Python 最好的地方就是有大量的第三方庫能幫我們快速實現我們想要的方法,搜索到了兩個庫, 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)

需要注意圖片的文件名如果是純數字且位數不一樣,排序會為1之后是10而不是2,需要進行一個排序,如果是手機拍的文件就沒有這個問題。 files.sort(key=lambda x: int(x[:-4]))

旋轉圖片展示方向并壓縮像素

有的時候手機拍出來的圖片是水平的,需要將其改為豎直的用rotate旋轉方向的時候需要注意加上expand=True 這個參數,否則會有黑邊出現。

手機的照片像素太高,有的需要進行壓縮以保證最后生成的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)整體代碼

寫成腳本需要考慮的有很多,為了方便使用,需要將各種參數改為允許用戶輸入的。比如圖片文件夾所在的路徑,壓縮比之類的

from PIL import Imageimport osimport img2pdfflag = Falsewhile not flag: dirname = input('請輸入圖片文件夾所在路徑(例如d:/wlzcool):') flag = os.path.exists(dirname) if not flag:print('圖片文件夾所在路徑不存在!')saveflag = Falsewhile not saveflag: savedirname = input('請輸入目標圖片文件夾所在路徑(例如d:/wlzcool2):') saveflag = os.path.exists(savedirname) if not saveflag:print('圖片文件夾所在路徑不存在!')automakedir = input('是否自動創建對應文件夾?(是Y/否N):')if automakedir.strip().upper() == 'Y': os.makedirs(savedirname) saveflag = Truefiles = os.listdir(dirname)reductionFactor = int(input('請輸入長寬壓縮比(例如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('請輸入輸出文件名(例如:第一章):')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))整體代碼

寫成腳本需要考慮的有很多,為了方便使用,需要將各種參數改為允許用戶輸入的。比如圖片文件夾所在的路徑,壓縮比之類的

from PIL import Imageimport osimport img2pdfflag = Falsewhile not flag: dirname = input('請輸入圖片文件夾所在路徑(例如d:/wlzcool):') flag = os.path.exists(dirname) if not flag:print('圖片文件夾所在路徑不存在!')saveflag = Falsewhile not saveflag: savedirname = input('請輸入目標圖片文件夾所在路徑(例如d:/wlzcool2):') saveflag = os.path.exists(savedirname) if not saveflag:print('圖片文件夾所在路徑不存在!')automakedir = input('是否自動創建對應文件夾?(是Y/否N):')if automakedir.strip().upper() == 'Y': os.makedirs(savedirname) saveflag = Truefiles = os.listdir(dirname)reductionFactor = int(input('請輸入長寬壓縮比(例如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('請輸入輸出文件名(例如:第一章):')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環境,我們需要將腳本打包成exe方便在任意一臺電腦上使用。 使用 PyInstaller 來進行腳本的打包

安裝 PyInstaller

pip install pyinstaller

打包腳本

在腳本所在的路徑的cmd中執行以下命令即可

pyinstaller -F yourprogram.py總結

人生苦短,我用 Python,在強大的第三方庫幫助下,我們只需很少的時間就可以開發一個很有意思的小功能。

以上就是Python 多張圖片合并成一個pdf的參考示例的詳細內容,更多關于Python 圖片合并成pdf的資料請關注好吧啦網其它相關文章!

標簽: Python 編程
相關文章:
主站蜘蛛池模板: 亚洲一区在线视频观看 | 亚洲国产精品毛片∧v卡在线 | 91麻豆国产极品在线观看洋子 | 久久精品网站免费观看 | 国产自自拍 | 黄色片在线免费观看视频 | 国产精品热久久毛片 | 国产黄大片在线观看视频 | 欧美日韩国产在线观看一区二区三区 | 麻豆国产视频 | 欧美高清另类 | aⅴ一区二区三区无卡无码 aⅴ在线免费观看 | 大学生久久香蕉国产线观看 | 国产成人盗拍精品免费视频 | 性xxxxxxx动漫视频 | 久久中文字幕亚洲 | 成人在线网站 | 亚洲欧美日韩在线精品一区二区 | 亚洲精品永久一区 | 欧美日韩国产在线观看一区二区三区 | 亚洲精品亚洲人成在线观看麻豆 | 一级片免费 | 国产a级男女性高爱潮片 | 99久久国产综合精品成人影院 | 国产精品久久久久久久久久直 | 色综合夜夜嗨亚洲一二区 | 一区二区免费视频 | 精品一区二区三区免费毛片爱 | 国产乱视频在线观看播放 | 美女被网站免费看九色视频 | 亚洲成年网 | 午夜精品国产爱在线观看不卡 | 亚洲精品国产精品国自产 | 国产免费资源高清小视频在线观看 | 中文日产国产精品久久 | 久久综合精品不卡一区二区 | 国产在线视频自拍 | 欧美亚洲综合视频 | 日韩不卡在线 | 一级片黄色免费 | 目韩一区二区三区系列片丶 |