欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python+Tinify實(shí)現(xiàn)高效批量壓縮圖片

 更新時(shí)間:2025年02月24日 11:03:24   作者:小小續(xù)  
這篇文章主要為大家詳細(xì)介紹了Python如何利用Tinify實(shí)現(xiàn)高效批量壓縮圖片功能,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下

webpack本身可以壓縮圖片image-webpack-loader,但是打包時(shí)間長,圖片是有損壓縮為了圖片質(zhì)量采用Python tinify庫腳本壓縮

以下是一個(gè)基于 PythonTinify(TinyPNG)庫的圖片壓縮腳本,它可以 遞歸壓縮 指定目錄下的所有 JPG、PNG 和 WebP 圖片,并 統(tǒng)計(jì)壓縮前后的總大小及節(jié)省的空間。

一、代碼功能

  • 遍歷目錄及其子目錄,查找 jpgpngwebp 圖片文件
  • 使用 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)文章

  • pandas df.sample()的使用

    pandas df.sample()的使用

    本文主要介紹了pandas df.sample()的使用,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2022-08-08
  • Python 處理帶有 \u 的字符串操作

    Python 處理帶有 \u 的字符串操作

    這篇文章主要介紹了Python 處理帶有 \u 的字符串操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-03-03
  • 解決python打開https出現(xiàn)certificate verify failed的問題

    解決python打開https出現(xiàn)certificate verify failed的問題

    這篇文章主要介紹了解決python打開https出現(xiàn)certificate verify failed的問題,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • Python+pyecharts繪制雙動態(tài)曲線教程詳解

    Python+pyecharts繪制雙動態(tài)曲線教程詳解

    pyecharts 是一個(gè)用于生成 Echarts 圖表的類庫。Echarts 是百度開源的一個(gè)數(shù)據(jù)可視化 JS 庫。用 Echarts 生成的圖可視化效果非常棒。本文將用pyecharts繪制雙動態(tài)曲線,需要的可以參考一下
    2022-06-06
  • Python安裝.whl文件流程以及問題解決方法

    Python安裝.whl文件流程以及問題解決方法

    WHL文件是以Wheel格式保存的Python安裝包,Wheel是Python發(fā)行版的標(biāo)準(zhǔn)內(nèi)置包格式,下面這篇文章主要給大家介紹了關(guān)于Python安裝.whl文件流程以及問題解決方法的相關(guān)資料,文中通過實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-05-05
  • Python中列表的高級索引技巧分享

    Python中列表的高級索引技巧分享

    列表是?Python?中最常用的數(shù)據(jù)結(jié)構(gòu)之一,它允許你存儲多個(gè)元素,并且可以通過索引來訪問這些元素,本文將帶你深入了解?Python?列表的高級索引技巧,希望對大家有所幫助
    2025-01-01
  • Python爬蟲進(jìn)階之爬取某視頻并下載的實(shí)現(xiàn)

    Python爬蟲進(jìn)階之爬取某視頻并下載的實(shí)現(xiàn)

    這篇文章主要介紹了Python爬蟲進(jìn)階之爬取某視頻并下載的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • 剖析Python的Twisted框架的核心特性

    剖析Python的Twisted框架的核心特性

    這篇文章主要介紹了剖析Python的Twisted框架的核心特性,包括Twisted框架中reacter與Deferred等的關(guān)鍵用法,需要的朋友可以參考下
    2016-05-05
  • Tensor和NumPy相互轉(zhuǎn)換的方法

    Tensor和NumPy相互轉(zhuǎn)換的方法

    本文主要介紹了Tensor和NumPy相互轉(zhuǎn)換的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • Python如何實(shí)現(xiàn)動態(tài)數(shù)組

    Python如何實(shí)現(xiàn)動態(tài)數(shù)組

    這篇文章主要介紹了Python如何實(shí)現(xiàn)動態(tài)數(shù)組,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-11-11

最新評論