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()

简单的翻译小工具

原文地址:https://www.cnblogs.com/huny/p/14019294.html