Python+Tinify實(shí)現(xiàn)高效批量壓縮圖片
webpack本身可以壓縮圖片image-webpack-loader,但是打包時(shí)間長,圖片是有損壓縮為了圖片質(zhì)量采用Python tinify庫腳本壓縮
以下是一個(gè)基于 Python 的 Tinify(TinyPNG)庫的圖片壓縮腳本,它可以 遞歸壓縮 指定目錄下的所有 JPG、PNG 和 WebP 圖片,并 統(tǒng)計(jì)壓縮前后的總大小及節(jié)省的空間。
一、代碼功能
- 遍歷目錄及其子目錄,查找
jpg
、png
、webp
圖片文件 - 使用 Tinify API 進(jìn)行無損壓縮,保證圖片質(zhì)量
- 輸出壓縮前后大小對比,顯示節(jié)省空間
- 跳過已壓縮的圖片,避免重復(fù)操作
二、Python 代碼
import os import sys import tinify # 設(shè)置 Tinify API Key(請自行到 https://tinypng.com/developers 獲取) TINIFY_API_KEY = "your_tinify_api_key" tinify.key = TINIFY_API_KEY # 支持的圖片格式 SUPPORTED_FORMATS = (".jpg", ".jpeg", ".png", ".webp") # 遞歸壓縮圖片 def compress_images_in_directory(directory): total_original_size = 0 total_compressed_size = 0 compressed_count = 0 # 遍歷目錄及子目錄 for root, _, files in os.walk(directory): for file in files: if file.lower().endswith(SUPPORTED_FORMATS): # 僅處理指定格式的圖片 file_path = os.path.join(root, file) original_size = os.path.getsize(file_path) # 獲取原始文件大小 try: # 壓縮圖片 source = tinify.from_file(file_path) source.to_file(file_path) compressed_size = os.path.getsize(file_path) # 獲取壓縮后大小 compressed_count += 1 total_original_size += original_size total_compressed_size += compressed_size # 輸出壓縮日志 saved_size = original_size - compressed_size print(f"? 壓縮成功: {file_path} | 節(jié)省 {saved_size / 1024:.2f} KB") except tinify.errors.AccountError: print("? 賬戶驗(yàn)證失敗,請檢查 API Key 是否正確") sys.exit(1) except tinify.errors.ClientError: print(f"? 無法處理圖片: {file_path}") except tinify.errors.ServerError: print("? TinyPNG 服務(wù)器錯(cuò)誤,稍后再試") except Exception as e: print(f"? 發(fā)生錯(cuò)誤: {e}") # 總結(jié)壓縮結(jié)果 if compressed_count > 0: saved_space = total_original_size - total_compressed_size print("\n?? 壓縮統(tǒng)計(jì):") print(f"- 處理圖片數(shù)量: {compressed_count}") print(f"- 壓縮前總大小: {total_original_size / 1024:.2f} KB") print(f"- 壓縮后總大小: {total_compressed_size / 1024:.2f} KB") print(f"- 總共節(jié)省空間: {saved_space / 1024:.2f} KB") else: print("?? 未找到需要壓縮的圖片") # 獲取命令行參數(shù)(目標(biāo)目錄) if __name__ == "__main__": if len(sys.argv) < 2: print("? 請輸入要壓縮的目錄路徑") sys.exit(1) target_directory = sys.argv[1] if not os.path.isdir(target_directory): print("? 指定的路徑不是一個(gè)有效目錄") sys.exit(1) print(f"?? 開始壓縮目錄: {target_directory}\n") compress_images_in_directory(target_directory)
三、如何使用
安裝依賴
pip install tinify
獲取 Tinify API Key
- 到 TinyPNG API(tinypng.com/developers) 申請開發(fā)者 API Key
- 將
TINIFY_API_KEY = "your_tinify_api_key"
替換成你的 API Key
運(yùn)行腳本
python compress_images.py "/your/image/directory"
例如:
python compress_images.py "./images"
四、代碼優(yōu)化點(diǎn)
自動遞歸處理子目錄
檢查圖片格式,避免處理非圖片文件
異常處理(API 錯(cuò)誤、服務(wù)器異常、無效路徑)
輸出詳細(xì)的壓縮信息,統(tǒng)計(jì)節(jié)省空間
避免重復(fù)壓縮
五、運(yùn)行效果示例
?? 開始壓縮目錄: ./images
? 壓縮成功: ./images/photo1.jpg | 節(jié)省 45.3 KB
? 壓縮成功: ./images/photo2.png | 節(jié)省 30.7 KB
? 壓縮成功: ./images/subdir/photo3.webp | 節(jié)省 25.1 KB
?? 壓縮統(tǒng)計(jì):
- 處理圖片數(shù)量: 3
- 壓縮前總大小: 512.3 KB
- 壓縮后總大小: 411.2 KB
- 總共節(jié)省空間: 101.1 KB
這樣,你就可以 在 Webpack 構(gòu)建前,手動使用 Python 腳本批量壓縮圖片,減少 Webpack 打包時(shí)間,同時(shí)保持高畫質(zhì)!
到此這篇關(guān)于Python+Tinify實(shí)現(xiàn)高效批量壓縮圖片的文章就介紹到這了,更多相關(guān)Python壓縮圖片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
解決python打開https出現(xiàn)certificate verify failed的問題
這篇文章主要介紹了解決python打開https出現(xiàn)certificate verify failed的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-09-09Python+pyecharts繪制雙動態(tài)曲線教程詳解
pyecharts 是一個(gè)用于生成 Echarts 圖表的類庫。Echarts 是百度開源的一個(gè)數(shù)據(jù)可視化 JS 庫。用 Echarts 生成的圖可視化效果非常棒。本文將用pyecharts繪制雙動態(tài)曲線,需要的可以參考一下2022-06-06Python爬蟲進(jìn)階之爬取某視頻并下載的實(shí)現(xiàn)
這篇文章主要介紹了Python爬蟲進(jìn)階之爬取某視頻并下載的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12Python如何實(shí)現(xiàn)動態(tài)數(shù)組
這篇文章主要介紹了Python如何實(shí)現(xiàn)動態(tài)數(shù)組,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-11-11