用python对图片批量压缩和格式转换

Aidan075 等级 526 0 0

python作为简单、易学的编程语言,上手入门要容易许多。如果数据分析、机器学习、人工智能这些对你来说比较遥远,用python写一点实用的小脚本帮你解决问题、提高办公效率也是不错的。

图片缩放、格式转换是一个常见的需求,网上虽然有许多这样的工具,但是下载站的质量参差不齐,如果没注意的话非常容易中招。这样不如自己用python写一个,安全有保障。

主要用到了PIL对图像进行处理。tkinter用来做图形界面,方便打包分享使用。

实现效果

用python对图片批量压缩和格式转换

用python对图片批量压缩和格式转换

用python对图片批量压缩和格式转换

实现代码

import os  
from PIL import Image  
import tkinter  
import tkinter.filedialog  
import tkinter.messagebox  


class Window():  
    def __init__(self):  
        self.root = root = tkinter.Tk()  
        self.menu = tkinter.Menu(root)  
        self.submenu = tkinter.Menu(self.menu, tearoff=0)  
        root.config(menu=self.submenu)  
        self.Image = tkinter.StringVar()  
        self.Image.set('.bmp')  
        self.mstatus = tkinter.IntVar()  
        self.fstatus = tkinter.IntVar()  
        self.mstatus.set(0)  
        self.fstatus.set(0)  
        self.status = tkinter.StringVar()  
        self.label = tkinter.Label(root, text='输入百分比')  
        self.label.place(x=5, y=5)  
        self.entryNew = tkinter.Entry(root)  
        self.entryNew.place(x=70, y=5)  
        self.checkM = tkinter.Checkbutton(self.root, text='批量转换', command=self.OnCheckM, variable=self.mstatus,  
                                          onvalue=1, offvalue=0)  
        self.checkM.place(x=5, y=30)  
        self.label = tkinter.Label(root, text='选择文件')  
        self.label.place(x=5, y=55)  
        self.entryFile = tkinter.Entry(root)  
        self.entryFile.place(x=70, y=55)  
        self.BrowserFileButton = tkinter.Button(root, text='浏览', command=self.BrowserFile)  
        self.BrowserFileButton.place(x=220, y=55)  
        self.label = tkinter.Label(root, text='选择目录')  
        self.label.place(x=5, y=90)  
        self.entryDir = tkinter.Entry(root, state=tkinter.DISABLED)  
        self.entryDir.place(x=70, y=90)  
        self.BrowserDirButton = tkinter.Button(root, text='浏览', command=self.BrowserDir, state=tkinter.DISABLED)  
        self.BrowserDirButton.place(x=220, y=90)  

        self.checkF = tkinter.Checkbutton(root, text='改变文件格式', onvalue=1, offvalue=0, variable=self.fstatus,  
                                          command=self.OnCheckF)  
        self.checkF.place(x=5, y=120)  

        frame = tkinter.Frame(root, )  
        frame.place(x=10, y=150)  
        self.rBmp = tkinter.Radiobutton(frame, variable=self.Image, value='.bmp', text='BMP', state=tkinter.DISABLED)  
        self.rBmp.pack(anchor='w')  
        self.rJpg = tkinter.Radiobutton(frame, variable=self.Image, value='.jpg', text='JPG', state=tkinter.DISABLED)  
        self.rJpg.pack(anchor='w')  
        self.rPng = tkinter.Radiobutton(frame, variable=self.Image, value='.png', text='PNG', state=tkinter.DISABLED)  
        self.rPng.pack(anchor='w')  
        self.rGif = tkinter.Radiobutton(frame, variable=self.Image, value='.gif', text='GIF', state=tkinter.DISABLED)  
        self.rGif.pack(anchor='w')  
        self.ButtonCov = tkinter.Button(root, text='转换格式', command=self.Conv, )  
        self.ButtonCov.place(x=120, y=180)  
        self.statusLabel = tkinter.Label(root, textvariable=self.status, fg='red')  
        self.statusLabel.place(x=80, y=220)  

    def OnCheckM(self):  
        if not self.mstatus.get():  
            self.entryDir.config(state=tkinter.DISABLED)  
            self.entryFile.config(state=tkinter.NORMAL)  
            self.BrowserFileButton.config(state=tkinter.NORMAL)  
            self.BrowserDirButton.config(state=tkinter.DISABLED)  
        else:  
            self.entryDir.config(state=tkinter.NORMAL)  
            self.entryFile.config(state=tkinter.DISABLED)  
            self.BrowserFileButton.config(state=tkinter.DISABLED)  
            self.BrowserDirButton.config(state=tkinter.NORMAL)  

    def OnCheckF(self):  
        if not self.fstatus.get():  
            self.rBmp.config(state=tkinter.DISABLED)  
            self.rPng.config(state=tkinter.DISABLED)  
            self.rJpg.config(state=tkinter.DISABLED)  
            self.rGif.config(state=tkinter.DISABLED)  
        else:  
            self.rBmp.config(state=tkinter.NORMAL)  
            self.rPng.config(state=tkinter.NORMAL)  
            self.rJpg.config(state=tkinter.NORMAL)  
            self.rGif.config(state=tkinter.NORMAL)  

    def BrowserFile(self):  
        file = tkinter.filedialog.askopenfilename(title='Python player',  
                                                  filetypes=[('JPG', '*.jpg'), ('BMP', '*.bmp'), ('GIF', '*.gif'),  
                                                             ('PNG', '*.png')])  
        if file:  
            self.entryFile.delete(0, tkinter.END)  
            self.entryFile.insert(tkinter.END, file)  

    def BrowserDir(self):  
        directory = tkinter.filedialog.askdirectory(title='Python')  
        if directory:  
            self.entryDir.delete(0, tkinter.END)  
            self.entryDir.insert(tkinter.END, directory)  

    def make(self, file, format=None):  
        im = Image.open(file)  
        mode = im.mode  
        if mode not in ('L', 'RGB'):  
            im = im.convert('RGB')  
        width, height = im.size  
        s = self.entryNew.get()  
        if s == '':  
            tkinter.messagebox.showerror('出错啦', '请输入百分比')  
            return  
        else:  
            n = int(s)  
        nwidth = int(width * n / 100)  
        nheight = int(height * n / 100)  
        thumb = im.resize((nwidth, nheight), Image.ANTIALIAS)  
        if format:  
            thumb.save(file[:(len(file) - 4)] + '_thumb' + format)  
        else:  
            thumb.save(file[:(len(file) - 4)] + '_thumb' + file[-4:])  

    def Conv(self):  
        n = 0  
        if self.mstatus.get():  
            path = self.entryDir.get()  
            if path == "":  
                tkinter.messagebox.showerror('出错啦', '请选择路径')  
                return  
            filenames = os.listdir(path)  
            if self.fstatus.get():  
                f = self.Image.get()  
                print(f)  
                for filename in filenames:  
                    if filename[-3:] in ('bmp', 'jpg', 'gif', 'png'):  
                        self.make(path + '/' + filename, f)  
                        n += 1  
            else:  
                for filename in filenames:  
                    if filename[-3:] in ('bmp', 'jpg', 'gif', 'png'):  
                        self.make(path + '/' + filename)  
                        n += 1  
        else:  
            file = self.entryFile.get()  
            if file == '':  
                tkinter.messagebox.showerror('出错啦', '请选择文件')  
                return  
            if self.fstatus.get():  
                f = self.Image.get()  
                self.make(file, f)  
                n += 1  
            else:  
                self.make(file)  
                n += 1  
        self.status.set('成功转换 %d 张图片' % n)  

    def mainloop(self):  
        self.root.minsize(280, 270)  
        self.root.maxsize(280, 250)  
        self.root.title('图片转换')  
        self.root.mainloop()  


if __name__ == "__main__":  
    window = Window()  
    window.mainloop()  

本文转转自微信公众号快学Python原创https://mp.weixin.qq.com/s/XJUqSXDmzLO5Pc7jJt4Edw,可扫描二维码进行关注: 用python对图片批量压缩和格式转换 如有侵权,请联系删除。

收藏
评论区

相关推荐

15. Python 程序运行速度如何提高十倍?第一遍滚雪球学 Python 收工
本篇文章将给大家介绍 Python 多线程与多进程相关知识,学习完该知识点之后,你的 Python 程序将进入另一个高峰。 <center<font colorred缓解一下视疲劳</font</center 15. Python 程序运行速度如何提高十倍?第一遍滚雪球学 Python 收工(https://imghelloworld.oss
python装饰器详解
你会Python嘛? 我会! 那你给我讲下Python装饰器吧! Python装饰器啊?我没用过哎 以上是我一个哥们面试时候发生的真实对白。 \分割线
原来Python绘图也可以这么漂亮,这次真的是学习到了!
(https://imghelloworld.osscnbeijing.aliyuncs.com/8830803f033eeed85783e9058cf08968.png) 作者:朱小五 来源:快学Python 👆人生苦短,快学Python! 最近看了一篇文章《一个牛逼的Python 可视化库:PyG2Plot》,可惜只是简单介
Python中JSON的基本使用_Just do it !
JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式。Python3 中可以使用 json 模块来对 JSON 数据进行编解码,它主要提供了四个方法: dumps、dump、loads、load。 dump和dumps dump和dumps对python对象进行序列化。将一个Python对象
我的python总结
建议刚开始学习直接使用ANACONDAhttps://www.anaconda.com/download/配置python环境变量https://docs.python.org/3.6/using/cmdline.htmlenvvarPYTHONMALLOCPython PEP8导包顺序1. Python标准
tornado入门笔记
官方文档https://www.tornadoweb.org/en/stable/ 简单使用 /usr/bin/env python coding: utf8 Author: Wjyimport tornado.ioloop 启动import tornado.web 请求对象import tornado.tem
商业数据分析从入门到入职(8)Python模块、文件IO和面向对象
前言本文先介绍了Python中程序、模块和包的基本使用,并在此基础上介绍了Python标准库。然后详细介绍了Python中的文件IO操作,包括文本文件、二进制文件的读写和其他IO操作。最后介绍了面向对象,包括类的定义、继承的使用、鸭子类型和魔法方法。 一、程序、模块和包 1.自定义模块和包之前我们使用的.ipynb文件都不是纯Python文件,
如何用python进行数据分析——00环境配置
↑一个宝藏公众号,长的好看的人都关注了  简单介绍一下Python吧 Python是一种面向对象程序设计语言,由荷兰人吉多·范罗苏姆于1989年底发明。目前是最常用也是最热门的一门编程语言之一,应用非常广泛。 (不是这个面对对象) 为什么选择python呢? 有人说python是万能的,除了生孩子不会,什么都会。 有人说python是未来
Python初学者必备书籍《Python入门经典》高清PDF版|百度网盘免费下载|Python初学者,自学Python必读
提取码:1028以及前文提到的学习路线图内容简介Python是一种解释型、面向对象、动态数据类型的高级程序设计语言。Python可以用于很多的领域,从科学计算到游戏开发。《Python入门经典》是面向Python初学者的学习指南,详细介绍了Python编程基础,以及一些高级概念,如面向对象编程。全书分为24章。第1章介绍了Python的背景和安装方法。第2章
关于学习python的一点意见分享
Python适合初学者入门。Python作为一门叫做ABC语言的替代品。 Python提供了高效的高级数据结构,还能简单有效地面向对象编程。相比其他主流语言,有更好的可读性,上手相对容易。各种模块,免去了很多重复的工作,更快地写出东西。配置环境也不复杂,mac和linux内置了Python。自学python,最大的3个经验:.一本易懂,比较好的教程,从头到尾
python的学习难?你的方法不对罢了,看看我的。
1、选择Python版本对于使用python的人来说,python的版本就是我们的工作环境,因此,在学习之前需要考虑好学习哪个版本,python2和python3的版本不同,会存在一些差异,虽说不大,但直接学习python3 的话相对来说会好一点,而且跑一趟还能3相对来说对零基础的小白来说更加的友好,容易上手。2、学习Python基础知识Python 是一个
全网最全python学习路线图,让学习不迷路
学习Python有一段时间了,最近也是在不断的整理Python相关的基础知识和学习一些新的知识,想来分享给大家。我刚开始接触Python时,和大多数初学者一样不知道从那里开始学习python,我也在网上找了许多python相关的资料来学习,但是资料多也不见得就好,因为不知道从哪里开始下手,走了许多弯路。后面我就整理了一套对初学者来说学习python能很快上手
python的这些必备干货知识点,快来看看有没有你不了解的?
Python是当前主流的编程语言之一,其优点有:一:语法简洁,可以让使用者用少量的代码完成相对复杂的效果。二:标准库和第三库多,功能强大;三:站在了人工智能和大数据的风口上;像国内的豆瓣呀,知乎呀等等知名网站都是基于python开发的,而Youtube、Reddit、Dropbpx也是用python的框架开发的。近几年学习python的小伙伴越来越多,那么p
手把手教你使用Flask搭建ES搜索引擎(预备篇)
/1 前言/ Elasticsearch 是一个开源的搜索引擎,建立在一个全文搜索引擎库 Apache Lucene™ 基础之上。 那么如何实现 Elasticsearch和 Python 的对接成为我们所关心的问题了 (怎么什么都要和 Python 关联啊)。 /2 Python 交互/ 所以,Python 也就提供了可以对接 Elasti
10行Python代码自动清理电脑内重复文件,解放双手!
](https://mp.weixin.qq.com/mp/appmsgalbum?actiongetalbum&albumid1337012041701326848&bizMzI1MTUyMjc1Mgwechatredirect) 前言 大家好,又到了Python办公自动化系列。今天分享一个系统层面的自动化案例:「给定一个文件夹,使用Python检查