• Python GUI之Tkiner实战


    前言

    Tkinter 是 Python 的标准 GUI 库。Python 使用 Tkinter 可以快速的创建 GUI 应用程序。
    由于 Tkinter 是内置到 python 的安装包中、只要安装好 Python 之后就能 import Tkinter 库、而且 IDLE 也是用 Tkinter 编写而成、对于简单的图形界面 Tkinter 还是能应付自如。

    语法

    部件

    Tkinter提供了各种控件,例如GUI应用程序中使用的按钮,标签和文本框。这些控件通常称为小部件。
    Tkinter当前有15种类型的小部件。下表中列出了这些小部件以及简要说明-

    部件 描述
    Button 按钮控件;在程序中显示按钮。
    Canvas 画布控件;显示图形元素如线条或文本
    Checkbutton 多选框控件;用于在程序中提供多项选择框
    Entry 输入控件;用于显示简单的文本内容
    Frame 框架控件;在屏幕上显示一个矩形区域,多用来作为容器
    Label 标签控件;可以显示文本和位图
    Listbox 列表框控件;在Listbox窗口小部件是用来显示一个字符串列表给用户
    Menubutton 菜单按钮控件,用于显示菜单项。
    Menu 菜单控件;显示菜单栏,下拉菜单和弹出菜单
    Message 消息控件;用来显示多行文本,与label比较类似
    Radiobutton 单选按钮控件;显示一个单选的按钮状态
    Scale 范围控件;显示一个数值刻度,为输出限定范围的数字区间
    Scrollbar 滚动条控件,当内容超过可视化区域时使用,如列表框。.
    Text 文本控件;用于显示多行文本
    Toplevel 容器控件;用来提供一个单独的对话框,和Frame比较类似
    Spinbox 输入控件;与Entry类似,但是可以指定输入范围值
    PanedWindow PanedWindow是一个窗口布局管理的插件,可以包含一个或者多个子控件。
    LabelFrame labelframe 是一个简单的容器控件。常用与复杂的窗口布局。
    tkMessageBox 用于显示你应用程序的消息框。

    标准属性

    让我们看一下如何指定它们的一些常见属性,例如大小,颜色和字体。

    属性 描述
    属性 描述
    Dimension 控件大小;
    Color 控件颜色;
    Font 控件字体;
    Anchor 锚点;
    Relief 控件样式;
    Bitmap 位图;
    Cursor 光标;

    几何管理

    所有的Tkinter小部件都可以访问特定的几何管理方法,该方法的目的是在整个父小部件区域中组织小部件。Tkinter公开以下几何图形管理器类:包装,网格和位置。

    几何方法 描述
    pack() 包装;
    grid() 网格;
    place() 位置;

    示例1

    #!/usr/bin/python
    # -*- coding: utf-8 -*-
    # author:Huny
    
    import tkinter as tk
    import tkinter.messagebox
    #实例对象
    window = tk.Tk()
    #标题
    window.title('Huny之家')
    window.geometry('500x300')
    #加载图片
    canvas = tk.Canvas(window,width=400,height=135,bg='green')#创建画布
    image_file = tk.PhotoImage(file='pic.gif')#添加图片的路径
    image = canvas.create_image(200,0,anchor='n',image=image_file)#创建图片并声明大小和位置以及图片的路径
    canvas.pack(side='top')
    tk.Label(window,text='Wellcome',font=('Arial',16)).pack()#声明一个小部件并放在父部件window中
    #名称
    tk.Label(window,text='用户名').place(x=50,y=165)
    tk.Label(window,text='密码').place(x=50,y=200)
    #文本和密码输入框、登录按钮
    var_usr_name = tk.StringVar()#记录输入值的变量
    var_usr_name.set('huny')#设置默认用户名
    e1 =tk.Entry(window, textvariable=var_usr_name,font=('Arial',14))#定义一个文本框和字体,接受文本框中的值
    var_usr_pwd = tk.StringVar()
    e2 =tk.Entry(window, textvariable=var_usr_pwd,font=('Arial',14))
    e1.pack()#将小部件组织成块,然后再将其放置在主小部件中
    e2.pack()
    #登录弹窗提示功能
    def login():
        usr_name = var_usr_name.get()
        usr_pwd = var_usr_pwd.get()
        user_info = {'huny':'123456'}
        if usr_name in user_info:
            if usr_pwd == '123456':
                tkinter.messagebox.showinfo(title='欢迎来到Huny之家',message='登录成功!')#正确的弹窗提示
            else:
                tkinter.messagebox.showerror(title='提醒',message='密码错误!')#错误的弹窗提示
        else:
            tkinter.messagebox.showerror(title='提醒',message='用户名错误')#错误的弹窗提示
    e3 = tk.Button(window,text="登录",width=10,height=2,command=login)#声明一个按钮部件
    e3.pack()
    window.mainloop()#循环执行可以理解为保持窗口运行,否则界面不展示
    

    简单的登录界面判断

    示例2

    #!/usr/bin/ python
    # -*- coding: utf-8 -*-
    import urllib.request
    import urllib.parse
    import json
    from tkinter import *
    import hashlib
    import time
    
    LOG_LINE_NUM = 0
    
    class MY_GUI():
        def __init__(self,init_window_name):
            self.init_window_name = init_window_name
    
    
        #设置窗口
        def set_init_window(self):
            self.init_window_name.title("翻译工具")           #窗口名
            # self.init_window_name.geometry('320x160+10+10')                         #290 160为窗口大小,+10 +10 定义窗口弹出时的默认展示位置
            self.init_window_name.geometry('1080x581+10+10')
            self.init_window_name["bg"] = "green"                                    #窗口背景色,其他背景色见:blog.csdn.net/chl0000/article/details/7657887
            # self.init_window_name.attributes("-alpha",0.9)                          #虚化,值越小虚化程度越高
            #标签
            self.init_data_label = Label(self.init_window_name, text="待处理数据")
            self.init_data_label.grid(row=0, column=4)
            self.result_data_label = Label(self.init_window_name, text="输出结果")
            self.result_data_label.grid(row=0, column=16)
            self.log_label = Label(self.init_window_name, text="日志")
            self.log_label.grid(row=12, column=4)
            #文本框
            self.init_data_Text = Text(self.init_window_name, width=67, height=25)  #原始数据录入框
            self.init_data_Text.grid(row=1, column=0, rowspan=10, columnspan=10)
            self.result_data_Text = Text(self.init_window_name, width=70, height=39)  #处理结果展示
            self.result_data_Text.grid(row=1, column=12, rowspan=15, columnspan=10)
            self.log_data_Text = Text(self.init_window_name, width=66, height=12)  # 日志框
            self.log_data_Text.grid(row=13, column=0, columnspan=10)
            #按钮
            self.str_trans_to_md5_button = Button(self.init_window_name, text="一键翻译", bg="lightblue", width=8,command=self.translate)  # 调用内部方法  加()为直接调用
            self.str_trans_to_md5_button.grid(row=5, column=11)
    
    
        #功能函数
        def  translate(self):        
            centens = self.init_data_Text.get(1.0,END).strip().replace("
    ","")
            if centens:
                try:
                    url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'
                    data = {}
                    data['i'] = centens
                    data['from'] = 'AUTO'
                    data['to'] = 'AUTO'
                    data['smartresult'] = 'dict'
                    data['client'] = 'fanyideskweb'
                    data['salt'] = '16057996372935'
                    data['sign'] = '0965172abb459f8c7a791df4184bf51c'
                    data['lts'] = '1605799637293'
                    data['bv'] = 'f7d97c24a497388db1420108e6c3537b'
                    data['doctype'] = 'json'
                    data['version'] = '2.1'
                    data['keyfrom'] = 'fanyi.web'
                    data['action'] = 'FY_BY_REALTlME'
                    data = urllib.parse.urlencode(data).encode('utf-8')
                    response = urllib.request.urlopen(url,data)
                    html = response.read().decode('utf-8')
                    req = json.loads(html)
                    result = req['translateResult'][0][0]['tgt']
                    self.result_data_Text.delete(1.0,END)
                    self.result_data_Text.insert(1.0,result)
                    self.write_log_to_Text("INFO:str_trans_ success")
                except:
                    self.result_data_Text.delete(1.0,END)
                    self.result_data_Text.insert(1.0,"操作错误")
            else:
                self.write_log_to_Text("ERROR:str_trans_ failed")
                        
        #获取当前时间
        def get_current_time(self):
            current_time = time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))
            return current_time
    
        #日志动态打印
        def write_log_to_Text(self,logmsg):
            global LOG_LINE_NUM
            current_time = self.get_current_time()
            logmsg_in = str(current_time) +" " + str(logmsg) + "
    "      #换行
            if LOG_LINE_NUM <= 7:
                self.log_data_Text.insert(END, logmsg_in)
                LOG_LINE_NUM = LOG_LINE_NUM + 1
            else:
                self.log_data_Text.delete(1.0,2.0)
                self.log_data_Text.insert(END, logmsg_in)
    
    def gui_start():
        init_window = Tk()              #实例化出一个父窗口
        ZMJ_PORTAL = MY_GUI(init_window)
        # 设置根窗口默认属性
        ZMJ_PORTAL.set_init_window()
        init_window.mainloop()          #父窗口进入事件循环,可以理解为保持窗口运行,否则界面不展示
    
    gui_start()
    

    简单的翻译小工具

  • 相关阅读:
    Oracle学习(一)SQL基础
    结构型设计模式(二)桥接模式
    dubbo学习(十)spring boot整合dubbo
    dubbo学习(九)dubbo监控中心
    结构型设计模式(一)适配器模式
    取石子游戏
    卡特兰数
    做题中踩过的坑。。。
    51Nod1130斯特林近似
    51Nod1089最长回文子串 V2(Manacher算法)
  • 原文地址:https://www.cnblogs.com/huny/p/14019294.html
Copyright © 2020-2023  润新知