python3 tkinter如何绑定事

发布时间:2019-07-31 09:30:51编辑:auto阅读(1815)

    一、目的

    在上一篇《python3 实现自动生成入账记录表》说到通过编辑bat文件进行参数的输入不是很方便,本篇就是用tkinter模块制作输入信息界面,输入完成点击’ok’键,触发写好的脚本,使得自动生成入款对账记录表格。

    二、tkinter安装说明

    python3.5版本,tkinter是内置模块,无需另外进行安装。使用tkinter,只要 import tkinter 。

    三、思路

    1. 整理原先写好的自动生成记账记录表脚本,把脚本封装成一个函数A。
    2. 用tkinter制作一个信息输入界面,输入商户编号、开始时间和结束时间,点击OK键触发参数传入到已封装好的函数A,并自动生成入款对账记录表。

    四、附上代码

    • tkinter绑定自动生成入账记录表格事件,代码如下:

    import tkinter as tk
    import time,datetime
    from tkinter import *
    import tkinter.messagebox
    from oracle_ss import get_oracle_data
    /#运行的python文件和需要导入的python文件在一个目录的话,则不需要写包名 orui.oracle_ss import ..)

    class MainWindow:

    def buttonListener1(self, event):#创建事件,调用另外一个函数的功能,生成表格
        agent_no=self.text_agentno.get(1.0, tk.END)#获取text_agentno文本框里的值
        stime = self.text_stime.get(1.0, tk.END)
        etime = self.text_etime.get(1.0, tk.END)
        #get_oracle_date()就是自己封装好的自动生成入账记录的函数,这里调用这个函数就可以
        get_oracle_data(agent_no,stime,etime)
        tk.messagebox.showinfo("messagebox", "云+入账对账记录表格已自动生成")
    
    def buttonListener2(self, event):#创建第二个事件,退出程序
        exit()
    
    def __init__(self):
        #创建Frame
        self.frame = Tk()
        # 设置Frame这个矩形区域的标题
        self.frame.title('欢迎使用,请输入信息:')
        #向frame中添加3个label
        self.label_agentno = 
        Label(self.frame, text="商户编号:",fg="blue",font="Verdana 10 bold")
        self.label_stime = 
        Label(self.frame, text="开始时间:",fg="blue",font="Verdana 10 bold")
        self.label_etime = 
        Label(self.frame, text="结束时间:",fg="blue",font="Verdana 10 bold")
    
        self.text_agentno = Text(self.frame, height="1", width=30)
        #商户编号设置默认值为20000xxxxxxx
        self.text_agentno.insert(1.0,'20000xxxxxxx')
        self.text_stime = Text(self.frame, height="1", width=30)
        now_time=datetime.datetime.now()
        yes_time=now_time+datetime.timedelta(days=-1)
        #开始时间设置默认值为前一天年月日0时0分0秒
        self.text_stime.insert(1.0,yes_time.strftime("%Y-%m-%d")+" 00:00:00")
        self.text_etime = Text(self.frame, height="1", width=30)
        #结束时间设置默认值为当前时间年月日0时0分0秒
        self.text_etime.insert(1.0,now_time.strftime("%Y-%m-%d")+" 00:00:00")
    
        #使用grid来布局组件,指定组件放置在什么位置
        self.label_agentno.grid(row=0, column=0)
        self.label_stime.grid(row=1, column=0)
        self.label_etime.grid(row=2, column=0)
    
        self.button_ok = Button(self.frame, text="ok", width=10)
        self.button_cancel = Button(self.frame, text="cancel", width=10)
    
        #使用grid设置各个label位置
        self.text_agentno.grid(row=0, column=1)
        self.text_stime.grid(row=1, column=1)
        self.text_etime.grid(row=2, column=1)
    
        self.button_ok.grid(row=3, column=0)
        self.button_cancel.grid(row=3, column=1)
    
        self.button_ok.bind("<Button-1>",self.buttonListener1)
        #绑定事件—点击OK键,tkinter自动捕获并触发buttonListener1事件,生成表格
    
        self.button_cancel.bind("<Button-1>",self.buttonListener2)
        #绑定事件—点击取消键,tkinter自动捕获并触发buttonListener2事件,退出程序
        self.frame.mainloop()
    

    frame = MainWindow()
    input(“Enter the any press to exit”)

    • get_oracle_data()函数的代码,这里不再重复贴出来。只要对上一篇《python3.5 实现自动生成入账记录表》的代码稍微整理封装一下就能被调用。

    五、总结

    1. 针对tkinter模块,大部分都是看python官网文档和各种相关博客现学现用的,很多知识点可能我也了解的不透彻。针对界面需要输入开始时间和结束时间的参数,本想着弄一个日历插件,让使用者选择时间,但是看了下至少要再弄2个事件:其中一个是点击按钮触发打开日历事件;另外一个就是选择日期触发时间指传递事件。最后想了还是用最简单的方法,用insert()方法给开始时间和结束时间都设置了一个默认值,用户可在默认值上直接修改时间,这样也方便用户使用。
    2. 双击写好的aa.bat文件,自动运行脚本,出现输入信息界面。秀秀界面,如下截图:
      这里写图片描述
      这里写图片描述

关键字