Python+Tinify實(shí)現(xiàn)高效批量壓縮圖片
webpack本身可以壓縮圖片image-webpack-loader,但是打包時(shí)間長(zhǎng),圖片是有損壓縮為了圖片質(zhì)量采用Python tinify庫(kù)腳本壓縮
以下是一個(gè)基于 Python 的 Tinify(TinyPNG)庫(kù)的圖片壓縮腳本,它可以 遞歸壓縮 指定目錄下的所有 JPG、PNG 和 WebP 圖片,并 統(tǒng)計(jì)壓縮前后的總大小及節(jié)省的空間。
一、代碼功能
- 遍歷目錄及其子目錄,查找
jpg、png、webp圖片文件 - 使用 Tinify API 進(jìn)行無(wú)損壓縮,保證圖片質(zhì)量
- 輸出壓縮前后大小對(duì)比,顯示節(jié)省空間
- 跳過(guò)已壓縮的圖片,避免重復(fù)操作
二、Python 代碼
import os
import sys
import tinify
# 設(shè)置 Tinify API Key(請(qǐng)自行到 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("? 賬戶(hù)驗(yàn)證失敗,請(qǐng)檢查 API Key 是否正確")
sys.exit(1)
except tinify.errors.ClientError:
print(f"? 無(wú)法處理圖片: {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("? 請(qǐng)輸入要壓縮的目錄路徑")
sys.exit(1)
target_directory = sys.argv[1]
if not os.path.isdir(target_directory):
print("? 指定的路徑不是一個(gè)有效目錄")
sys.exit(1)
print(f"?? 開(kāi)始?jí)嚎s目錄: {target_directory}\n")
compress_images_in_directory(target_directory)
三、如何使用
安裝依賴(lài)
pip install tinify
獲取 Tinify API Key
- 到 TinyPNG API(tinypng.com/developers) 申請(qǐng)開(kāi)發(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)
自動(dòng)遞歸處理子目錄
檢查圖片格式,避免處理非圖片文件
異常處理(API 錯(cuò)誤、服務(wù)器異常、無(wú)效路徑)
輸出詳細(xì)的壓縮信息,統(tǒng)計(jì)節(jié)省空間
避免重復(fù)壓縮
五、運(yùn)行效果示例
?? 開(kāi)始?jí)嚎s目錄: ./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)建前,手動(dòng)使用 Python 腳本批量壓縮圖片,減少 Webpack 打包時(shí)間,同時(shí)保持高畫(huà)質(zhì)!
到此這篇關(guān)于Python+Tinify實(shí)現(xiàn)高效批量壓縮圖片的文章就介紹到這了,更多相關(guān)Python壓縮圖片內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Python使用pywebview開(kāi)發(fā)桌面應(yīng)用的全過(guò)程
當(dāng)使用桌面應(yīng)用程序的時(shí)候,有沒(méi)有那么一瞬間,想學(xué)習(xí)一下桌面應(yīng)用程序開(kāi)發(fā)?下面這篇文章主要給大家介紹了關(guān)于Python使用pywebview開(kāi)發(fā)桌面應(yīng)用的相關(guān)資料,需要的朋友可以參考下2022-06-06
Python matplotlib 繪制雙Y軸曲線(xiàn)圖的示例代碼
Matplotlib是非常強(qiáng)大的python畫(huà)圖工具,這篇文章主要介紹了Python matplotlib 繪制雙Y軸曲線(xiàn)圖,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06
Python實(shí)現(xiàn)身份證號(hào)碼驗(yàn)證的示例代碼
本文主要介紹了Python實(shí)現(xiàn)身份證號(hào)碼驗(yàn)證的示例代碼,當(dāng)用戶(hù)輸入身份證號(hào),按下檢查按鈕,即可判斷身份證號(hào)是否正確,具有一定的參考價(jià)值,感興趣的可以了解一下2024-02-02
Python基于回溯法子集樹(shù)模板解決全排列問(wèn)題示例
這篇文章主要介紹了Python基于回溯法子集樹(shù)模板解決全排列問(wèn)題,簡(jiǎn)單描述了全排列問(wèn)題并結(jié)合實(shí)例形式分析了Python使用回溯法子集樹(shù)模板解決全排列問(wèn)題的具體步驟與相關(guān)操作注意事項(xiàng),需要的朋友可以參考下2017-09-09
Python實(shí)現(xiàn)驗(yàn)證碼識(shí)別
這篇文章主要介紹了Python實(shí)現(xiàn)驗(yàn)證碼識(shí)別的方法,文中講解非常詳細(xì),代碼幫助大家更好的理解和學(xué)習(xí),感興趣的朋友可以了解下2020-06-06
opencv3/C++ 平面對(duì)象識(shí)別&透視變換方式
今天小編就為大家分享一篇opencv3/C++ 平面對(duì)象識(shí)別&透視變換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12
Python采集某度貼吧排行榜實(shí)戰(zhàn)示例
這篇文章主要為大家介紹了Python采集某度貼吧排行榜實(shí)戰(zhàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
Python入門(mén)之三角函數(shù)tan()函數(shù)實(shí)例詳解
這篇文章主要介紹了Python入門(mén)之三角函數(shù)tan()的相關(guān)內(nèi)容,介紹了tan()函數(shù)的描述,語(yǔ)法以及簡(jiǎn)單實(shí)例,具有一定參考價(jià)值,需要的朋友可以了解下。2017-11-11

