Python基于tkinter模块实现的改名小工具示例
作者:一花一世界,一叶一乾坤 发布时间:2023-08-31 10:40:01
标签:Python,tkinter
本文实例讲述了Python基于tkinter模块实现的改名小工具。分享给大家供大家参考,具体如下:
#!/usr/bin/env python
#coding=utf-8
#
# 版权所有 2014 yao_yu
# 本代码以MIT许可协议发布
# 文件名批量加.xls后缀
# 2014-04-21 创建
#
import os
import tkinter as tk
from tkinter import ttk
version = '2014-04-21'
app_title = '文件名批量加后缀 Ver:' + version
listdir = os.listdir
isdir = os.path.isdir
isfile = os.path.isfile
path_join = os.path.join
#---------------------------- Object Visit ----------------------------#
def visit_directory_files(root, visitor):
for i in listdir(root):
i = path_join(root, i)
if isdir(i):
if visit_directory_files(i, visitor):
return True
elif isfile(i):
if visitor(i):
return True
#---------------------------- Visitor ----------------------------#
class ListVisitor(object):
def __init__(self, *visitors, terminate = True):
if (visitors
and isinstance(visitors, (list, tuple))
and isinstance(visitors[0], (list, tuple))):
visitors = visitors[0]
self._visitors = list(visitors)
self._terminate = terminate
def __call__(self, *args, **kwdargs):
for visitor in self._visitors:
if visitor(*args, **kwdargs):
return self._terminate
def append(self, visitor):
assert(visitor)
self._visitors.append(visitor)
def get_screen_size(window):
return window.winfo_screenwidth(),window.winfo_screenheight()
def get_window_size(window):
return window.winfo_reqwidth(),window.winfo_reqheight()
def center_window(root, width, height):
screenwidth = root.winfo_screenwidth()
screenheight = root.winfo_screenheight()
size = '%dx%d+%d+%d' % (width, height, (screenwidth - width)/2, (screenheight - height)/2)
root.geometry(size)
class Application(object):
def __init__(self, master):
self.master = ttk.Frame(master)
self.master.pack(side = tk.TOP, expand = tk.YES, fill = tk.BOTH)
self.create_widgets()
def create_widgets(self):
master = self.master
master.columnconfigure(1, weight=1)
master.rowconfigure(2, weight=1)
self.targetdir = tk.StringVar()
self.targetdir.set('/Volumes/Data/Document/Test')
padx = 5
pady = 10
ttk.Label(master, text="操作目录").grid(row = 0, column = 0, stick = tk.E, padx = padx, pady = pady)
ttk.Entry(master, textvariable = self.targetdir).grid(row = 0, column = 1, stick = tk.EW, padx = padx)
commands = ttk.Frame(master)
commands.grid(row = 1, column = 0, columnspan = 2)
ttk.Button(commands, text="开始", command = self.onStart).pack(side = tk.LEFT)
ttk.Button(commands, text="退出", command = master.quit).pack(side = tk.LEFT)
self.status = tk.StringVar()
self.status.set('就绪')
master.rowconfigure(3, minsize = 160)
ttk.Label(master, textvariable = self.status, wraplength=600).grid(row = 3, column = 0, columnspan = 2, padx = padx, stick = tk.NSEW)
self.progress = ttk.Progressbar(master, maximum=100, orient=tk.HORIZONTAL, mode='determinate')
self.progress.grid(row = 4, column = 0, columnspan = 2, padx = padx, stick = tk.NSEW)
def onStart(self):
targetdir = self.targetdir.get().strip()
basename = os.path.basename(targetdir)
if os.path.isdir(targetdir):
listvisitor = ListVisitor(ProgressVisitor(self.progress),
self.StatusVisitor(),
FileLogVisitor(basename),
#FileRenameVisitor(basename),
)
visit_directory_files(targetdir, listvisitor)
else:
self.status.set('目标目录不存在')
def StatusVisitor(self):
print_status = self.status.set
def __call__(file):
__call__.n += 1
print_status('%s,%s' % (__call__.n, file))
__call__.n = 0
return __call__
splitext = os.path.splitext
file_rename = os.rename
knownexts = dict.fromkeys(['.jpg', '.log', '.pdf', '.tif', '.xls', '.zip', '.rar'])
class FileRenameVisitor(object):
def __init__(self, file):
self.__fp = open('%s_%s_rename.txt' % (os.path.splitext(__file__)[0], file), 'w')
def __call__(self, file):
ext = splitext(file)[1].lower()
if ext not in knownexts:
file_rename(file, file + '.xls')
self.__fp.write('%s\n' % file)
def __del__(self):
self.__fp.close()
class FileLogVisitor(object):
def __init__(self, file):
self.__fp = open('%s_%s_all.txt' % (os.path.splitext(__file__)[0], file), 'w')
def __call__(self, file):
self.__fp.write('%s\n' % file)
def __del__(self):
self.__fp.close()
class ProgressVisitor(object):
COUNT = 202
def __init__(self, progress, count=COUNT):
self.progress = progress
if count and isinstance(count, int) and count > 0:
self.count = count
else:
self.count = self.COUNT
self.n = 1
def __call__(self, *args, **kwdargs):
self.n += 1
if self.n == self.count:
self.progress.step()
self.progress.update()
self.n = 1
def __del__(self):
self.progress['value'] = 0
if __name__ == '__main__':
root = tk.Tk()
root.title(app_title)
app = Application(root)
center_window(root, 600, 240)
tk.mainloop()
希望本文所述对大家Python程序设计有所帮助。


猜你喜欢
- 那么四年一度的世界杯即将要在卡塔尔开幕了,对于不少热爱足球运动的球迷来说,这可是十分难得的盛宴,而对于最后大力神杯的归属,相信很多人都满怀着
- Python 类Python中的类提供了面向对象编程的所有基本功能:类的继承机制允许多个基类,派生类可以覆盖基类中的任何方法,方法中可以调用
- 什么是变量在Python编程语言中,变量是用于存储数据值的标识符。它们可以用来引用数据值,而不是直接使用值本身。可以使用等号(=)运算符来将
- 在工作中碰到这么一个问题:给定一个已经排序的数组(升序),删除数组中重复的数据,但是只能使用一个数组,这个数组的大小可以变化. 例子:&nb
- 使用MySQL的命令终端时,如果输入SQL有误,将有beep声。若要关闭该功能,根据mysql --help,使用mysql --no-be
- 1. mmap内存映射文件建立一个文件的内存映射将使用操作系统虚拟内存来直接访问文件系统上的数据,而不是使用常规的I/O函数访问数据。内存映
- 之前在做数据分析的过程中,需要对数据进行实时的写入,比如对新生成的数据写入之前已经生成的txt或csv文件中。现在想想其实很简单,所以做一个
- 背景: 在我们使用Golang进行开发过程中,总是绕不开对字符或字符串的处理,而在Golang语言中,对字符和字符串的处理方式可能和其他语言
- 一.使用库说明Golang中连接kafka可以使用第三方库:github.com/Shopify/sarama二.Kafka Produce
- 在采集网页信息的时候,经常需要伪造报头来实现采集脚本的有效执行下面,我们将使用urllib2的header部分伪造报头来实现采集信息方法1、
- 1、ElementUi文档已经说了,如果需要后端排序,需将sortable设置为custom,同时在 Table 上监听sort-chang
- asp日期转换星座函数,参数是日期型function astro(birth)astro=""if
- sys模块提供了与python解释器紧密相关的一些变量和函数。sys部分常用函数函数说明path获取模块文件搜索路径的字符串,或临时指定新搜
- 1、chr(i)chr()函数返回ASCII码对应的字符串。>>> print chr(65)A>>>
- 本文实例讲述了Python 面向对象静态方法、类方法、属性方法知识点。分享给大家供大家参考,具体如下:(1)静态方法--》-@staticm
- 最近一直在整理统计图表的绘制方法,发现Python中除了经典Seaborn库外,还有一些优秀的可交互的第三方库也能实现一些常见的统计图表绘制
- mtx文件是按照稀疏矩阵格式存储的矩阵数据,可以按照以下步骤读取:1、安装scanpy包pip install scanpy2、文件读取im
- 谈到用户界面交互总少不了事件,前面一系列文章介绍的鼠标光标、坐标、弹出式提示框等实现的底层其实都是事件处理,只不过matplotlib或其他
- AJAX简介AJAX = Asynchronous JavaScript and XML(异步的 JavaScript 和 XML)。AJA
- 核心代码: header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); head