Python+Tinify实现高效批量压缩图片

 更新时间:2025年02月24日 11:03:24   作者:小小续  
这篇文章主要为大家详细介绍了Python如何利用Tinify实现高效批量压缩图片功能,文中的示例代码讲解详细,感兴趣的小伙伴可以了解一下

webpack本身可以压缩图片image-webpack-loader,但是打包时间长,图片是有损压缩为了图片质量采用Python tinify库脚本压缩

以下是一个基于 PythonTinify(TinyPNG)库的图片压缩脚本,它可以 递归压缩 指定目录下的所有 JPG、PNG 和 WebP 图片,并 统计压缩前后的总大小及节省的空间

一、代码功能

  • 遍历目录及其子目录,查找 jpgpngwebp 图片文件
  • 使用 Tinify API 进行无损压缩,保证图片质量
  • 输出压缩前后大小对比,显示节省空间
  • 跳过已压缩的图片,避免重复操作

二、Python 代码

import os
import sys
import tinify

# 设置 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} | 节省 {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 服务器错误,稍后再试")
                except Exception as e:
                    print(f"❌ 发生错误: {e}")

    # 总结压缩结果
    if compressed_count > 0:
        saved_space = total_original_size - total_compressed_size
        print("\n📊 压缩统计:")
        print(f"- 处理图片数量: {compressed_count}")
        print(f"- 压缩前总大小: {total_original_size / 1024:.2f} KB")
        print(f"- 压缩后总大小: {total_compressed_size / 1024:.2f} KB")
        print(f"- 总共节省空间: {saved_space / 1024:.2f} KB")
    else:
        print("⚠️ 未找到需要压缩的图片")

# 获取命令行参数(目标目录)
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) 申请开发者 API Key
  • TINIFY_API_KEY = "your_tinify_api_key" 替换成你的 API Key

运行脚本

python compress_images.py "/your/image/directory"

例如:

python compress_images.py "./images"

四、代码优化点

自动递归处理子目录

检查图片格式,避免处理非图片文件

异常处理(API 错误、服务器异常、无效路径)

输出详细的压缩信息,统计节省空间

避免重复压缩

五、运行效果示例

🚀 开始压缩目录: ./images

✅ 压缩成功: ./images/photo1.jpg | 节省 45.3 KB
✅ 压缩成功: ./images/photo2.png | 节省 30.7 KB
✅ 压缩成功: ./images/subdir/photo3.webp | 节省 25.1 KB

📊 压缩统计:
- 处理图片数量: 3
- 压缩前总大小: 512.3 KB
- 压缩后总大小: 411.2 KB
- 总共节省空间: 101.1 KB

这样,你就可以 在 Webpack 构建前手动使用 Python 脚本批量压缩图片,减少 Webpack 打包时间,同时保持高画质

到此这篇关于Python+Tinify实现高效批量压缩图片的文章就介绍到这了,更多相关Python压缩图片内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • Python使用pywebview开发桌面应用的全过程

    Python使用pywebview开发桌面应用的全过程

    当使用桌面应用程序的时候,有没有那么一瞬间,想学习一下桌面应用程序开发?下面这篇文章主要给大家介绍了关于Python使用pywebview开发桌面应用的相关资料,需要的朋友可以参考下
    2022-06-06
  • Python matplotlib 绘制双Y轴曲线图的示例代码

    Python matplotlib 绘制双Y轴曲线图的示例代码

    Matplotlib是非常强大的python画图工具,这篇文章主要介绍了Python matplotlib 绘制双Y轴曲线图,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-06-06
  • Python实现身份证号码验证的示例代码

    Python实现身份证号码验证的示例代码

    本文主要介绍了Python实现身份证号码验证的示例代码,当用户输入身份证号,按下检查按钮,即可判断身份证号是否正确,具有一定的参考价值,感兴趣的可以了解一下
    2024-02-02
  • Python基于回溯法子集树模板解决全排列问题示例

    Python基于回溯法子集树模板解决全排列问题示例

    这篇文章主要介绍了Python基于回溯法子集树模板解决全排列问题,简单描述了全排列问题并结合实例形式分析了Python使用回溯法子集树模板解决全排列问题的具体步骤与相关操作注意事项,需要的朋友可以参考下
    2017-09-09
  • Python实现验证码识别

    Python实现验证码识别

    这篇文章主要介绍了Python实现验证码识别的方法,文中讲解非常详细,代码帮助大家更好的理解和学习,感兴趣的朋友可以了解下
    2020-06-06
  • python的help函数如何使用

    python的help函数如何使用

    在本篇文章里小编给大家整理的是关于python的help函数的相关用法和知识点总结,需要的朋友们可以学习下。
    2020-06-06
  • opencv3/C++ 平面对象识别&透视变换方式

    opencv3/C++ 平面对象识别&透视变换方式

    今天小编就为大家分享一篇opencv3/C++ 平面对象识别&透视变换方式,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2019-12-12
  • Python采集某度贴吧排行榜实战示例

    Python采集某度贴吧排行榜实战示例

    这篇文章主要为大家介绍了Python采集某度贴吧排行榜实战示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-04-04
  • python爬取酷狗音乐Top500榜单

    python爬取酷狗音乐Top500榜单

    大家好,本篇文章主要讲的是python爬取酷狗音乐Top500榜单,感兴趣的同学赶快来看一看吧,对你有帮助的话记得收藏一下
    2022-02-02
  • Python入门之三角函数tan()函数实例详解

    Python入门之三角函数tan()函数实例详解

    这篇文章主要介绍了Python入门之三角函数tan()的相关内容,介绍了tan()函数的描述,语法以及简单实例,具有一定参考价值,需要的朋友可以了解下。
    2017-11-11

最新评论