Python3.4 tkinter,PIL图片转换
时间:2019-04-20
本文章向大家介绍Python3.4 tkinter,PIL图片转换,主要包括Python3.4 tkinter,PIL图片转换使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
先给大家分享一下全部代码
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) self.submenu.add_command(label='作者: 王小涛同?W') 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()
运行后的实际效果如下
感谢大家对脚本之家的支持,欢迎提出宝贵意见。
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Linux基础:进程管理
- Android实现顶部悬浮效果
- Linux基础:性能监控
- pstack 跟踪进程栈
- android实现左右侧滑菜单效果
- 排查守候在零点两分的 bug
- Android中TextView实现部分文字可点击跳转
- Android viewpager自动轮播和小圆点联动效果
- 用Redis构建缓存集群的最佳实践有哪些?
- Android实现IP地址输入框的方法示例代码
- Node.js 搭建 HTTPS 服务器
- Android布局之表格布局TableLayout详解
- 简单实现Android倒计时效果
- Android实现单页面浮层可拖动view的一种方法
- 排查 Node.js 服务内存泄漏,没想到竟是它?