当前位置: 首页 > article >正文

Python 图片压缩工具

Python 图片压缩工具

1.简介:

本工具是一个独立的单文件应用程序,使用Python编写,具备图形用户界面(GUI),旨在帮助用户对图片进行有损压缩,以减少图片文件的大小。该工具支持JPEG、PNG、BMP和GIF等常见图片格式
直接双击下载的单文件应用程序即可启动程序,无需进行任何安装步骤。可自定义压缩级别,默认50%,默认保存在同目录,可选保存目录。结尾附源码,程序已打包成exe单文件,大家可自行下载,喜欢请点个关注哦,主页还有更多干货资源!

使用说明:

  1. 启动程序双击单文件应用程序,程序的主界面将自动打开。
  2. 选择图片点击界面上的“选择图片”按钮,从本地文件系统中选择需要压缩的图片文件。
  3. 预览图片选择图片后,程序界面将显示所选图片的缩略图预览。
  4. 设置压缩级别通过界面上的滑块设置压缩级别。滑块的值从1到99,数值越大,压缩级别越高,图片质量越低。数值为1时,会反向压缩。
  5. 选择保存位置点击“浏览…”按钮,选择压缩后图片的保存位置。如果不进行选择,压缩后的图片将保存在与原图片相同的目录下。
  6. 压缩图片完成压缩级别和保存位置的设置后,点击“压缩图片”按钮以开始压缩过程。
  7. 查看结果压缩完成后,程序将弹出一个信息框告知用户压缩成功,并提供压缩后图片的保存路径。

2.运行效果:

在这里插入图片描述
在这里插入图片描述

压缩前

在这里插入图片描述

压缩后

在这里插入图片描述

画质基本无损

在这里插入图片描述

3.相关源码:

import tkinter as tk
from tkinter import filedialog, messagebox, StringVar
from tkinter import ttk
from PIL import Image, ImageTk
import os
from datetime import datetime
 
class ImageCompressorApp:
    def __init__(self, root):
        self.root = root
        self.root.title("图片压缩工具")
        self.selected_save_dir = StringVar(value="")
        self.file_path = None
 
        # 设置窗口的默认大小为屏幕尺寸的50%
        screen_width = root.winfo_screenwidth()
        screen_height = root.winfo_screenheight()
        default_width = int(screen_width * 0.5)
        default_height = int(screen_height * 0.5)
        self.root.geometry(f"{default_width}x{default_height}+{int((screen_width - default_width)/2)}+{int((screen_height - default_height)/2)}")
 
        # 主要容器
        main_frame = ttk.Frame(root)
        main_frame.grid(row=0, column=0, sticky="nsew")
 
        # 左侧选项区域
        options_frame = ttk.Frame(main_frame, padding="20")
        options_frame.grid(row=0, column=0, sticky="nsew")
 
        # 图片选择按钮
        self.select_button = ttk.Button(options_frame, text="选择图片", command=self.select_file)
        self.select_button.grid(row=0, column=0, padx=5, pady=5, sticky="ew")
 
        # 压缩级别标签
        label_quality = ttk.Label(options_frame, text="压缩级别:")
        label_quality.grid(row=1, column=0, padx=5, pady=5, sticky="ew")
 
        # 压缩质量选择
        self.quality_scale = ttk.Scale(options_frame, from_=1, to=99, orient=tk.HORIZONTAL, command=self.update_quality_label)
        self.quality_scale.set(50)  # 默认压缩级别为50
        self.quality_scale.grid(row=1, column=1, padx=5, pady=5, sticky="ew")
 
        # 压缩质量标签
        self.quality_label_var = StringVar()
        self.quality_label = ttk.Label(options_frame, textvariable=self.quality_label_var)
        self.quality_label.grid(row=1, column=2, padx=5, pady=5, sticky="w")
        self.update_quality_label()  # 初始化标签文本
 
        # 压缩按钮
        self.compress_button = ttk.Button(options_frame, text="压缩图片", command=self.compress_image)
        self.compress_button.grid(row=2, column=0, columnspan=3, padx=5, pady=5, sticky="ew")
 
        # 保存位置标签
        save_dir_label = ttk.Label(options_frame, text="保存位置:")
        save_dir_label.grid(row=3, column=0, padx=5, pady=5, sticky="ew")
 
        # 保存位置输入框
        self.save_dir_entry = ttk.Entry(options_frame, textvariable=self.selected_save_dir)
        self.save_dir_entry.grid(row=3, column=1, columnspan=2, padx=5, pady=5, sticky="ew")
 
        # 浏览按钮
        self.browse_button = ttk.Button(options_frame, text="浏览...", command=self.choose_save_dir)
        self.browse_button.grid(row=4, column=0, columnspan=3, padx=5, pady=5, sticky="ew")
 
        # 右侧预览区域
        self.preview_frame = ttk.Frame(main_frame, padding="10", borderwidth=2, relief="flat", style="Preview.TFrame")
        self.preview_frame.grid(row=0, column=1, sticky="nsew")
 
        self.preview_label = ttk.Label(self.preview_frame, text="图片预览:", anchor="w")
        self.preview_label.pack(side=tk.TOP, fill=tk.X, padx=5, pady=5)
 
        self.image_panel = tk.Label(self.preview_frame, bg="white", width=300, height=300)
        self.image_panel.pack(side=tk.TOP, fill=tk.BOTH, expand=True)
 
        # 设置背景颜色
        self.root.config(bg="#F5F5F5")
        self.preview_frame.config(style="Preview.TFrame")
 
    def select_file(self):
        self.file_path = filedialog.askopenfilename(
            title="选择图片文件",
            filetypes=[("图片文件", "*.jpg;*.jpeg;*.png;*.bmp;*.gif")]
        )
        if self.file_path:
            self.show_preview()
            self.selected_save_dir.set(os.path.dirname(self.file_path))  # 默认保存在图片相同目录
 
    def show_preview(self):
        if self.file_path:
            img = Image.open(self.file_path)
            img.thumbnail((300, 300))  # 调整图片大小以适应预览窗口
            img_tk = ImageTk.PhotoImage(img)
 
            self.preview_label.config(image=img_tk)
            self.preview_label.image = img_tk  # 保持对图像的引用
 
    def choose_save_dir(self):
        save_dir = filedialog.askdirectory(title="选择保存位置")
        if save_dir:
            self.selected_save_dir.set(save_dir)  # 更新保存目录
 
    def compress_image(self):
        if not self.file_path:
            messagebox.showwarning("未选择文件", "请先选择一个图片文件。")
            return
 
        quality = 100 - int(self.quality_scale.get())  # 转换为压缩质量
 
        if not 1 <= quality <= 99:
            messagebox.showerror("错误", "无效的压缩级别设置。")
            return
 
        try:
            save_dir = self.selected_save_dir.get()
            if not save_dir:
                save_dir = os.path.dirname(self.file_path)  # 如果没有选择保存目录,使用图片所在的目录
 
            new_file_path = self.do_image_compression(quality, save_dir)
            messagebox.showinfo("压缩完成", f"图片压缩完成!\n新文件路径: {new_file_path}")
        except Exception as e:
            messagebox.showerror("错误", f"压缩过程中发生错误: {e}")
 
    def do_image_compression(self, quality, save_dir):
        img = Image.open(self.file_path)
        timestamp = datetime.now().strftime("%Y%m%d_%H%M%S")
        file_extension = os.path.splitext(self.file_path)[1]
        new_file_name = os.path.splitext(os.path.basename(self.file_path))[0] + f"_{timestamp}_comp{file_extension}"
        new_file_path = os.path.join(save_dir, new_file_name)
 
        if img.format == "JPEG":
            img.save(new_file_path, optimize=True, quality=quality)
        else:
            new_img = img.convert('RGB')
            new_img.save(new_file_path, format='JPEG', quality=quality)
 
        return new_file_path
 
    def update_quality_label(self, *args):
        quality = int(self.quality_scale.get())
        self.quality_label_var.set(f"({quality})")
 
if __name__ == "__main__":
    root = tk.Tk()
    app = ImageCompressorApp(root)
    root.mainloop()
    root.mainloop()
    root.mainloop()
    root.mainloop()

http://www.kler.cn/a/454011.html

相关文章:

  • 初始JavaEE篇 —— 网络原理---传输层协议:深入理解UDP/TCP
  • 【踩坑/Linux】Vmware中的Ubuntu虚拟机无法访问互联网
  • Linux高级--3.3.2.6高并发编程之“内存屏障”“CPU屏障”“编译屏障”
  • 3350、检测相邻递增子数组 Ⅱ
  • 中科岩创桥梁自动化监测解决方案
  • 对gPTP上PTP安全控制的评估
  • Tengine平替Nginx
  • 代码随想录day27 贪心1
  • 使用 Python 操作 Excel 表格
  • js垃圾回收机制详细讲解
  • IntelliJ Idea常用快捷键详解
  • 数据分析思维(五):分析方法——假设检验分析方法
  • R 语言 | 绘图的文字格式(绘制上标、下标、斜体、文字标注等)
  • 接口测试Day03-postman使用接口用例设计
  • vscode 插件一直提示正在安装的问题
  • Linux 的 Regmap API:简化设备寄存器访问
  • 新一代Web安全技术应用指南
  • 音视频入门知识(二)、图像篇
  • FPGA开发实战之“模块实例化中的端口映射陷阱”
  • HDLBits训练4