Python+Tinify實現(xiàn)高效批量壓縮圖片
webpack本身可以壓縮圖片image-webpack-loader,但是打包時間長,圖片是有損壓縮為了圖片質(zhì)量采用Python tinify庫腳本壓縮
以下是一個基于 Python 的 Tinify(TinyPNG)庫的圖片壓縮腳本,它可以 遞歸壓縮 指定目錄下的所有 JPG、PNG 和 WebP 圖片,并 統(tǒng)計壓縮前后的總大小及節(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("? 賬戶驗證失敗,請檢查 API Key 是否正確")
sys.exit(1)
except tinify.errors.ClientError:
print(f"? 無法處理圖片: {file_path}")
except tinify.errors.ServerError:
print("? TinyPNG 服務(wù)器錯誤,稍后再試")
except Exception as e:
print(f"? 發(fā)生錯誤: {e}")
# 總結(jié)壓縮結(jié)果
if compressed_count > 0:
saved_space = total_original_size - total_compressed_size
print("\n?? 壓縮統(tǒng)計:")
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("? 指定的路徑不是一個有效目錄")
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)化點
自動遞歸處理子目錄
檢查圖片格式,避免處理非圖片文件
異常處理(API 錯誤、服務(wù)器異常、無效路徑)
輸出詳細(xì)的壓縮信息,統(tǒng)計節(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)計:
- 處理圖片數(shù)量: 3
- 壓縮前總大小: 512.3 KB
- 壓縮后總大小: 411.2 KB
- 總共節(jié)省空間: 101.1 KB
這樣,你就可以 在 Webpack 構(gòu)建前,手動使用 Python 腳本批量壓縮圖片,減少 Webpack 打包時間,同時保持高畫質(zhì)!
到此這篇關(guān)于Python+Tinify實現(xiàn)高效批量壓縮圖片的文章就介紹到這了,更多相關(guān)Python壓縮圖片內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python使用pywebview開發(fā)桌面應(yīng)用的全過程
當(dāng)使用桌面應(yīng)用程序的時候,有沒有那么一瞬間,想學(xué)習(xí)一下桌面應(yīng)用程序開發(fā)?下面這篇文章主要給大家介紹了關(guān)于Python使用pywebview開發(fā)桌面應(yīng)用的相關(guān)資料,需要的朋友可以參考下2022-06-06
Python matplotlib 繪制雙Y軸曲線圖的示例代碼
Matplotlib是非常強(qiáng)大的python畫圖工具,這篇文章主要介紹了Python matplotlib 繪制雙Y軸曲線圖,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-06-06
Python入門之三角函數(shù)tan()函數(shù)實例詳解
這篇文章主要介紹了Python入門之三角函數(shù)tan()的相關(guān)內(nèi)容,介紹了tan()函數(shù)的描述,語法以及簡單實例,具有一定參考價值,需要的朋友可以了解下。2017-11-11

