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

Aidan075
• 阅读 1135

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对图片批量压缩和格式转换 如有侵权,请联系删除。

点赞
收藏
评论区
推荐文章
blmius blmius
2年前
MySQL:[Err] 1292 - Incorrect datetime value: ‘0000-00-00 00:00:00‘ for column ‘CREATE_TIME‘ at row 1
文章目录问题用navicat导入数据时,报错:原因这是因为当前的MySQL不支持datetime为0的情况。解决修改sql\mode:sql\mode:SQLMode定义了MySQL应支持的SQL语法、数据校验等,这样可以更容易地在不同的环境中使用MySQL。全局s
Jacquelyn38 Jacquelyn38
2年前
2020年前端实用代码段,为你的工作保驾护航
有空的时候,自己总结了几个代码段,在开发中也经常使用,谢谢。1、使用解构获取json数据let jsonData  id: 1,status: "OK",data: 'a', 'b';let  id, status, data: number   jsonData;console.log(id, status, number )
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
Karen110 Karen110
2年前
​一篇文章总结一下Python库中关于时间的常见操作
前言本次来总结一下关于Python时间的相关操作,有一个有趣的问题。如果你的业务用不到时间相关的操作,你的业务基本上会一直用不到。但是如果你的业务一旦用到了时间操作,你就会发现,淦,到处都是时间操作。。。所以思来想去,还是总结一下吧,本次会采用类型注解方式。time包importtime时间戳从1970年1月1日00:00:00标准时区诞生到现在
Stella981 Stella981
2年前
Python3:sqlalchemy对mysql数据库操作,非sql语句
Python3:sqlalchemy对mysql数据库操作,非sql语句python3authorlizmdatetime2018020110:00:00coding:utf8'''
Wesley13 Wesley13
2年前
4cast
4castpackageloadcsv.KumarAwanish发布:2020122117:43:04.501348作者:KumarAwanish作者邮箱:awanish00@gmail.com首页:
Stella981 Stella981
2年前
Python之time模块的时间戳、时间字符串格式化与转换
Python处理时间和时间戳的内置模块就有time,和datetime两个,本文先说time模块。关于时间戳的几个概念时间戳,根据1970年1月1日00:00:00开始按秒计算的偏移量。时间元组(struct_time),包含9个元素。 time.struct_time(tm_y
Wesley13 Wesley13
2年前
00:Java简单了解
浅谈Java之概述Java是SUN(StanfordUniversityNetwork),斯坦福大学网络公司)1995年推出的一门高级编程语言。Java是一种面向Internet的编程语言。随着Java技术在web方面的不断成熟,已经成为Web应用程序的首选开发语言。Java是简单易学,完全面向对象,安全可靠,与平台无关的编程语言。
Wesley13 Wesley13
2年前
MySQL部分从库上面因为大量的临时表tmp_table造成慢查询
背景描述Time:20190124T00:08:14.70572408:00User@Host:@Id:Schema:sentrymetaLast_errno:0Killed:0Query_time:0.315758Lock_
Python进阶者 Python进阶者
3个月前
Excel中这日期老是出来00:00:00,怎么用Pandas把这个去除
大家好,我是皮皮。一、前言前几天在Python白银交流群【上海新年人】问了一个Pandas数据筛选的问题。问题如下:这日期老是出来00:00:00,怎么把这个去除。二、实现过程后来【论草莓如何成为冻干莓】给了一个思路和代码如下:pd.toexcel之前把这