Python: tkinter实例 更名小工具

#!/usr/bin/env python
#coding=utf-8
# 
# 版权所有 2014 yao_yu (http://blog.csdn.net/yao_yu_126)
# 本代码以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()

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
这是一个VB6的IDE插件(Addin),使用VB6的IDE直接设计Python的界面。 Python和VB都是能让人快乐的编程语言,我使用了Python之后,很多自己使用的工具都使用Python开发或改写了,因为最终实现的Python代码实在太短了(相比VB),有时候Python一行代码就可以实现VB一个函数的功能。 Python就是这种让人越用越开心的语言。 不过说实在,使用Python开发GUI界面还是麻烦了一些了,自带的标准库Tkinter使用起来非常简单,不过对于习惯了VB拖放控件完成界面设计的同学来说,还是不够人性化。TK也有一个工具叫GUI Builder,不过它使用Layout布局,不够直观,而且界面简陋,用起来也不爽。 至于PyQt/wxPython等GUI库,尽管有可视化设计工具,但总感觉做一般的轻量级应用是杀鸡用牛刀,学习起来也比较复杂,而且不够环保,不够低碳,要带一个很大的库,需要目标机器上夜同样安装了PyQt/wxPython,做不了绿色软件。 所以最终的结果是我更喜欢Tkinter,用起来很简单,绿色环保,真正的跨平台,一个py文件到处运行(担心泄密就编译成pyc)。 很多人都认为TK的界面不够美观,不过导入Python自带的标准TTK主题库,界面非常Native,不输PyQt/wxPython。 此Addin默认启用TTK支持,也可选择关闭。 总而言之,轻量级GUI,TK+TTK足够。 使用此Addin,你可以不用写一句代码就可以生成一个完整可运行的Python的GUI界面,支持python 2.X和3.X。 安装方法:将压缩包解压到你希望的目录,然后执行Setup.exe完成注册插件过程,打开VB6就可以用了。 在VB窗体上设计完成界面后(你可以大胆的设置各控件的属性,Addin尽量将其翻译为tkinter的控件属性),点工具栏上的VisualTkinter(图标为一片橙红色羽毛),再点'生成代码'按钮,即可生成可运行的Python代码,可以拷贝至剪贴板或保存至文件。 一般情况下你可以不用再改变tkinter的控件属性,但是如果你熟悉tkinter,需要更多的控制,可以一一核对各属性,并且修改,再生成代码。 除了用来设计界面外,此ADDIN内置的各控件属性列表可以做为编程参考,比较完整,除了极少数我认为大多数人都不用的属性外,属性定义基本上是我从官方的tkinter文档直接翻译的。 如果还没有VB6,网上找一个VB6精简版即可(建议使用12M的版本,6M的版本也可以使用,不过工具栏图标无法显示,可以通过菜单执行此插件)。 经过网友测试,完美支持WinXP,Windows 7, Windows 8。
这是一个VB6的IDE插件(Addin),使用VB6的IDE直接设计Python的界面。 Python和VB都是能让人快乐的编程语言,我使用了Python之后,很多自己使用的工具都使用Python开发或改写了,因为最终实现的Python代码实在太短了(相比VB),有时候Python一行代码就可以实现VB一个函数的功能。 Python就是这种让人越用越开心的语言。 不过说实在,使用Python开发GUI界面还是麻烦了一些了,自带的标准库Tkinter使用起来非常简单,不过对于习惯了VB拖放控件完成界面设计的偶来说,还是不够人性化。TK也有一个工具叫GUI Builder,不过它使用Layout布局,不够直观,而且用起来很不爽。。 至于PyQt/wxPython等GUI库,尽管有可视化设计工具,但总感觉做一般的轻量级应用是杀鸡用牛刀, 而且不够环保,不够低碳,要带一个很大的库,需要目标机器上夜同样安装了PyQt/wxPython,做不了绿色软件。 所以最终的结果是我更喜欢Tkinter,用起来很简单,绿色环保,真正的跨平台,一个py文件到处运行(担心泄密就编译成pyc)。 很多人都认为TK的界面不够美观,不过我经过多次实验后发现导入Python自带的标准TTK主题库,界面非常Native,不输PyQt/wxPython。 此Addin默认启用TTK支持,也可选择关闭。 总而言之,轻量级GUI,TK+TTK足够。 使用此Addin,你可以不用写一句代码就可以生成一个完整可运行的Python的GUI界面,支持2.X和3.X。 安装方法:将压缩包解压到你希望的目录,然后执行Setup.exe完成注册插件过程,打开VB6就可以用了。 在VB窗体上设计完成界面后(你可以大胆的设置各控件的属性,Addin尽量将其翻译为tkinter的控件属性),点工具栏上的VisualTkinter(图标为一片羽毛),再点'生成代码'按钮,即可生成可运行的Python代码,可以拷贝至剪贴板或保存至文件。 一般情况下你可以不用再改变tkinter的控件属性,但是如果你熟悉tkinter,需要更多的控制,可以一一核对各属性,并且修改,再生成代码。 当然除了用来设计界面外,此ADDIN内置的各控件属性列表可以做为编程参考,比较完整,除了极少数我认为大多数人都不用的属性外,属性定义基本上是我从官方的tkinter文档直接翻译的。 如果还没有VB6,网上找一个VB6精简版即可,不到20M,小巧玲珑。 代码已经在Github上托管,更新的版本可以在这上面找到,需求也可以在上面提: https://github.com/cdhigh/Visual-Tkinter-for-Python

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值