前言

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

简单的登录界面判断



示例2

  1. #!/usr/bin/ python
  2. # -*- coding: utf-8 -*-
  3. import urllib.request
  4. import urllib.parse
  5. import json
  6. from tkinter import *
  7. import hashlib
  8. import time
  9. LOG_LINE_NUM = 0
  10. class MY_GUI():
  11. def __init__(self,init_window_name):
  12. self.init_window_name = init_window_name
  13. #设置窗口
  14. def set_init_window(self):
  15. self.init_window_name.title("翻译工具") #窗口名
  16. # self.init_window_name.geometry('320x160+10+10') #290 160为窗口大小,+10 +10 定义窗口弹出时的默认展示位置
  17. self.init_window_name.geometry('1080x581+10+10')
  18. self.init_window_name["bg"] = "green" #窗口背景色,其他背景色见:blog.csdn.net/chl0000/article/details/7657887
  19. # self.init_window_name.attributes("-alpha",0.9) #虚化,值越小虚化程度越高
  20. #标签
  21. self.init_data_label = Label(self.init_window_name, text="待处理数据")
  22. self.init_data_label.grid(row=0, column=4)
  23. self.result_data_label = Label(self.init_window_name, text="输出结果")
  24. self.result_data_label.grid(row=0, column=16)
  25. self.log_label = Label(self.init_window_name, text="日志")
  26. self.log_label.grid(row=12, column=4)
  27. #文本框
  28. self.init_data_Text = Text(self.init_window_name, width=67, height=25) #原始数据录入框
  29. self.init_data_Text.grid(row=1, column=0, rowspan=10, columnspan=10)
  30. self.result_data_Text = Text(self.init_window_name, width=70, height=39) #处理结果展示
  31. self.result_data_Text.grid(row=1, column=12, rowspan=15, columnspan=10)
  32. self.log_data_Text = Text(self.init_window_name, width=66, height=12) # 日志框
  33. self.log_data_Text.grid(row=13, column=0, columnspan=10)
  34. #按钮
  35. self.str_trans_to_md5_button = Button(self.init_window_name, text="一键翻译", bg="lightblue", width=8,command=self.translate) # 调用内部方法 加()为直接调用
  36. self.str_trans_to_md5_button.grid(row=5, column=11)
  37. #功能函数
  38. def translate(self):
  39. centens = self.init_data_Text.get(1.0,END).strip().replace("\n","")
  40. if centens:
  41. try:
  42. url = 'http://fanyi.youdao.com/translate?smartresult=dict&smartresult=rule'
  43. data = {}
  44. data['i'] = centens
  45. data['from'] = 'AUTO'
  46. data['to'] = 'AUTO'
  47. data['smartresult'] = 'dict'
  48. data['client'] = 'fanyideskweb'
  49. data['salt'] = '16057996372935'
  50. data['sign'] = '0965172abb459f8c7a791df4184bf51c'
  51. data['lts'] = '1605799637293'
  52. data['bv'] = 'f7d97c24a497388db1420108e6c3537b'
  53. data['doctype'] = 'json'
  54. data['version'] = '2.1'
  55. data['keyfrom'] = 'fanyi.web'
  56. data['action'] = 'FY_BY_REALTlME'
  57. data = urllib.parse.urlencode(data).encode('utf-8')
  58. response = urllib.request.urlopen(url,data)
  59. html = response.read().decode('utf-8')
  60. req = json.loads(html)
  61. result = req['translateResult'][0][0]['tgt']
  62. self.result_data_Text.delete(1.0,END)
  63. self.result_data_Text.insert(1.0,result)
  64. self.write_log_to_Text("INFO:str_trans_ success")
  65. except:
  66. self.result_data_Text.delete(1.0,END)
  67. self.result_data_Text.insert(1.0,"操作错误")
  68. else:
  69. self.write_log_to_Text("ERROR:str_trans_ failed")
  70. #获取当前时间
  71. def get_current_time(self):
  72. current_time = time.strftime('%Y-%m-%d %H:%M:%S',time.localtime(time.time()))
  73. return current_time
  74. #日志动态打印
  75. def write_log_to_Text(self,logmsg):
  76. global LOG_LINE_NUM
  77. current_time = self.get_current_time()
  78. logmsg_in = str(current_time) +" " + str(logmsg) + "\n" #换行
  79. if LOG_LINE_NUM <= 7:
  80. self.log_data_Text.insert(END, logmsg_in)
  81. LOG_LINE_NUM = LOG_LINE_NUM + 1
  82. else:
  83. self.log_data_Text.delete(1.0,2.0)
  84. self.log_data_Text.insert(END, logmsg_in)
  85. def gui_start():
  86. init_window = Tk() #实例化出一个父窗口
  87. ZMJ_PORTAL = MY_GUI(init_window)
  88. # 设置根窗口默认属性
  89. ZMJ_PORTAL.set_init_window()
  90. init_window.mainloop() #父窗口进入事件循环,可以理解为保持窗口运行,否则界面不展示
  91. gui_start()

简单的翻译小工具

Python GUI之Tkiner实战的更多相关文章

  1. python GUI实战项目——tkinter库的简单实例

    一.项目说明: 本次通过实现一个小的功能模块对Python GUI进行实践学习.项目来源于软件制造工程的作业.记录在这里以复习下思路和总结编码过程.所有的源代码和文件放在这里: 链接: https:/ ...

  2. Python GUI - tkinter

    目录: Tkinter 组件 标准属性 几何管理 代码实例: 1. Label & Button 2. Entry & Text 3.Listbox列表 4.Radiobutton单选 ...

  3. Python GUI之tkinter窗口视窗教程大集合(看这篇就够了) JAVA日志的前世今生 .NET MVC采用SignalR更新在线用户数 C#多线程编程系列(五)- 使用任务并行库 C#多线程编程系列(三)- 线程同步 C#多线程编程系列(二)- 线程基础 C#多线程编程系列(一)- 简介

    Python GUI之tkinter窗口视窗教程大集合(看这篇就够了) 一.前言 由于本篇文章较长,所以下面给出内容目录方便跳转阅读,当然也可以用博客页面最右侧的文章目录导航栏进行跳转查阅. 一.前言 ...

  4. Python GUI 背景色与语法高亮主题配置

    [补充] Python GUI 中 :ALT+P 可以重复上一条命令. ---------------------------------------------------------------- ...

  5. Python-1 IDLE(Python GUI)

    #1 运行Python: 开始 -> 程序 -> Python -> IDLE(Python GUI) 或 开始 -> 输入IDLE #2 各个菜单项及基本用法的帮助: Hel ...

  6. Python GUI with Tkinter (from youtube) 在youtube上能找到很多编程视频...

    Python GUI with Tkinter - 1 - Introduction以上链接是一个python tkinter视频系列的第一讲的链接.虽然英语不好,但是,程序还是看得懂的(照着做就可以 ...

  7. 使用PyQt来编写第一个Python GUI程序

    原文:使用PyQt来编写第一个Python GUI程序 本文由 伯乐在线 - Lane 翻译,Daetalus 校稿.未经许可,禁止转载!英文出处:pythonforengineers.com.欢迎加 ...

  8. Python GUI开发环境的搭建

    原文:Python GUI开发环境的搭建 最近对Python的开发又来了兴趣,对于Python的开发一直停留在一个表面层的认识,玩的部分比较大. Python的入手简单,语法让人爱不释手,在网络通信方 ...

  9. Python GUI编程各种实现的对比

    Python GUI编程各种实现的对比 从 Python 语言的诞生之日起,就有许多优秀的 GUI 工具集整合到 Python 当中,这些优秀的 GUI 工具集,使得 Python 也可以在图形界面编 ...

随机推荐

  1. 【垃圾回收-CMS】Java内存回收实践经验 防止内存报警

    jdk6和7服务器端(-server) 默认的新生代的垃圾回收器为:PS Scavenge,老年代默认的垃圾回收器为:PS MarkSweep 目前项目使用了jdk7,tomcat7,经常出现内存堆使 ...

  2. JAVA代码实现抖音短视频去水印功能

    今天有人找我帮他抖音视频去水印,发到朋友圈,然后就研究了一下.去水印功能代码如下: public class DouYinQushuiyin { public static void main(Str ...

  3. HBase基础理论知识

    来源:第四章:大数据 の HBase 基础   本课主题 NoSQL 数据库介绍 HBase 基本操作 HBase 集群架构与设计介紹 HBase 与HDFS的关系 HBase 数据拆分和紧缩 引言 ...

  4. 在嵌入式设备中实现webrtc的第三种方式①

    最近两年,我对于网络知识,包括底层协议学习比较多,webrtc这种几乎是使用到了所有层面网络协议的技术也逐渐进入我的视野. 之前我提出了两种在嵌入式设备上实现webrtc的方式,一是用官方代码,然后改 ...

  5. Java数据结构-03单链表(二)

    在之前我们封装了一些操作在接口类中,并在抽象类实现了相同的方法.下面我们开始写代码: 无头结点单链表:(注意下面的AbstractList是之前抽取的类,不是java.util包下的类) public ...

  6. Redis 数据结构与编码技术 (Object Encoding)

    数据结构实现 相信大家对 redis 的数据结构都比较熟悉: string:字符串(可以表示字符串.整数.位图) list:列表(可以表示线性表.栈.双端队列.阻塞队列) hash:哈希表 set:集 ...

  7. leo101

    tags: 贪心 date: 2019-4-4 jag2017autumnJ Farm Village 题面 题目链接 翻译 数轴上有 n 个村庄,每个村庄可以生产两个单位的粮食.在每个村庄生产一单位 ...

  8. Linux 系统编程 学习 总结

    背景 整理了Liunx 关于 进程间通信的 很常见的知识. 目录 与 说明 Linux 系统编程 学习:000-有关概念 介绍了有关的基础概念,为以后的学习打下基础. Linux 系统编程 学习:00 ...

  9. CF957D Riverside Curio

    dp+预处理 dp[i]表示第i天时的水位线有多少条, 然后你会发现这个dp是有后效性的,当第i天的m[i]>dp[i-1]时就要修改之前的dp值 因此我们预处理出每一天的至少要多少条水位线,记 ...

  10. display:none;visibility:hidden;opacity:0;之间的区别

    什么是回流 当render tree中的一部分(或全部)因为元素的规模尺寸,布局,隐藏等改变而需要重新构建.这就称为回流(reflow).每个页面至少需要一次回流,就是在页面第一次加载的时候,这时候是 ...