大家好,今天本期带着大家制作一个属于自己的GUI图形化界面:用于设计签名的哦(效果如下图),是不是感觉很好玩,是不是很想学习呢?

限于篇幅,今天我们首先详细讲述一下Tkinter的使用方法。本来不准备详细讲述这个基础知识,但是我怕那些想学习的同学,学起来不过瘾,还是补充了这一章。喜欢记得收藏、关注、点赞。

【注】完整版代码、数据、技术交流文末获取

tkinter的简单应用

Tkinter是Python的标准GUI库。Python使用Tkinter可以快速地创建GUI应用程序。当然常用的GUI库还有PyQt5,我们只需要知道这两个常用的即可,如果你真的想学习的话。由于Tkinter属于Python标准库,就不需要使用pip安装,直接导入使用即可。

① 显示窗口
  • root.mainloop()显示窗口;

  • 窗口默认会显示在电脑屏幕的左上角,非常小(后面需要改进);

from tkinter import *
from tkinter import messagebox# 创建窗口:实例化一个窗口对象。
root = Tk()# 显示窗口
root.mainloop()
"""
注意到:该窗口默认的显示位置在哪里,观察我下面的截图。
窗口默认显示在整个电脑屏幕的左上角,并且窗口大小特别小。
"""

结果如下:

注意:上面2行代码,首先实例化一个窗口对象,然后我们展示了这个窗口,让其真正显示出来。接下来我们的操作,就是针对这个窗口的一系列优化操作,请注意:这个优化操作使用的代码,都是放在这2句代码中间。

② 设置窗口大小
  • root.geometry("600x400")调整窗口的大小;

  • 该方法中传入的是"宽x高",但是需要注意这个乘号是小写的英文字母x,而不是这个*表示的乘号;

from tkinter import *
from tkinter import messagebox# 创建窗口:实例化一个窗口对象。
root = Tk()# 窗口大小
root.geometry("600x450")# 显示窗口
root.mainloop()

结果如下:

③ 调整窗口位置(使用的是同一个方法)
  • root.geometry("600x400+374+182")调整窗口的大小+位置;

  • 374,182表示的是窗口顶点,距离电脑左上角的坐标。这个数字怎么得到的呢?直接借助微信截图就可以显示了。

操作代码如下:

from tkinter import *
from tkinter import messagebox# 创建窗口:实例化一个窗口对象。
root = Tk()# 窗口大小
root.geometry("600x450+374+182")# 显示窗口
root.mainloop()

结果如下:

④ 设置窗口的标题
  • root.title()设置窗口的标题;

  • 默认的窗口标题是tk;

from tkinter import *
from tkinter import messagebox# 创建窗口:实例化一个窗口对象。
root = Tk()# 窗口大小
root.geometry("600x450+374+182")#  窗口标题
root.title("我的个性签名设计")# 显示窗口
root.mainloop()

结果如下:

⑤ 添加标签控件,并定位
  • Label(root,text="签名")添加标签控件

  • 第一个参数传入的就是实例化的那个root窗口对象;第二个参数传入的要显示的那个标签文本;

  • 仅仅添加标签控件后,还不行,必须要指定一个位置后,该标签控件才会真正展示出来,即最后需要调用grid()方法后,才会显示标签控件;

from tkinter import *
from tkinter import messagebox# 创建窗口:实例化一个窗口对象。
root = Tk()# 窗口大小
root.geometry("600x450+374+182")#  窗口标题
root.title("我的个性签名设计")# 添加标签控件
label = Label(root)
# 定位
label.grid()# 显示窗口
root.mainloop()

结果如下:

当然你也可以想到,这个方法肯定还可以修改字体样式、字体大小、字体颜色呀?具体怎么操作呢?我们接着往下面看。

from tkinter import *
from tkinter import messagebox# 创建窗口:实例化一个窗口对象。
root = Tk()# 窗口大小
root.geometry("600x450+374+182")#  窗口标题
root.title("我的个性签名设计")# 添加标签控件
label = Label(root,text="签名",font=("宋体",25),fg="red")
"""
text参数用于指定显示的文本;
font参数用于指定字体大小和字体样式;
fg参数用于指定字体颜色;
"""
# 定位
label.grid()# 显示窗口
root.mainloop()

结果如下:

⑥ 添加输入框,并定位
  • Entry(root,font=("宋体",25),fg="red")添加输入框

  • 第一个参数传入的就是实例化的那个root窗口对象;第二个参数可写可不写,指的是我们输入的字体的字体样式和字体大小;第三个参数同样可写可不写,表示的是我们输入的字体的颜色。

  • 同样,仅仅使用上述代码并不会显示输入框,只有调用grid()方法,定位后,才会真正显示这个输入框;

from tkinter import *
from tkinter import messagebox# 创建窗口:实例化一个窗口对象。
root = Tk()# 窗口大小
root.geometry("600x450+374+182")#  窗口标题
root.title("我的个性签名设计")# 添加标签控件
label = Label(root,text="签名",font=("宋体",25),fg="red")
# 定位
label.grid()# 添加输入框
entry = Entry(root,font=("宋体",25),fg="red")
entry.grid()# 显示窗口
root.mainloop()

结果如下:

注意:很明显这样的摆放方式,并不是我们想要的。我们需要调整一下,下面我们专门花一个小节时间,去讲述怎么调整这个摆放位置。

⑦ 调整控件的摆放位置

首先我们需要搞明白,显示窗口究竟采用的是什么样子的布局方式呢?其实是网格式的布局方式。那么什么又是网格式的布局方式呢?excel表格你知道吧,一个个的格子就是网格式的布局方式。

好了!知道了上述原理后,我们现在来真正的调整这个控件摆放位置啦。

from tkinter import *
from tkinter import messagebox# 创建窗口:实例化一个窗口对象。
root = Tk()# 窗口大小
root.geometry("600x450+374+182")#  窗口标题
root.title("我的个性签名设计")# 添加标签控件
label = Label(root,text="签名:",font=("宋体",25),fg="red")
# 定位
label.grid()
"""
label.grid()等价于label.grid(row=0,column=0)
"""
# 添加输入框
entry = Entry(root,font=("宋体",25),fg="red")
entry.grid(row=0,column=1)
"""
row=0,column=1表示我们将输入框控件,放在第1行第2列的位置;
python语言中,这个下标是从0开始的。
"""
# 显示窗口
root.mainloop()

结果如下:

⑧ 添加点击按钮
  • Button(root,text="签名设计",font=("宋体",25),fg="red")添加输入框

  • 第一个参数传入的就是实例化的那个root窗口对象;第二个参数展示的是我们这个点击按钮的标签;第三个参数可写可不写,指的是点击按钮字体的字体样式和字体大小;第四个参数同样可写可不写,表示的是点击按钮字体的颜色。

  • 同样,仅仅使用上述代码并不会显示输入框,只有调用grid()方法,定位后,才会真正显示这个点击按钮;

from tkinter import *
from tkinter import messagebox# 创建窗口:实例化一个窗口对象。
root = Tk()# 窗口大小
root.geometry("600x450+374+182")#  窗口标题
root.title("我的个性签名设计")# 添加标签控件
label = Label(root,text="签名:",font=("宋体",25),fg="red")
# 定位
label.grid()# 添加输入框
entry = Entry(root,font=("宋体",25),fg="red")
entry.grid(row=0,column=1)# 添加点击按钮
button = Button(root,text="签名设计",font=("宋体",25),fg="blue")
button.grid(row=1,column=1)# 显示窗口
root.mainloop()

结果如下:

至此界面已经简单搭建起来了,接下来要做的就是输入一个名字,点击签名设计后,会显示我的这个签名,此时就需要借助爬虫啦!明天我们将会发布该文的下篇哦,敬请期待。

⑨ 点击按钮自定义功能

这里最后补充这个知识点,我们点击按钮后,总是希望能够给我们返回点什么,所以呢,需要我们自定义函数

from tkinter import *
from tkinter import messageboxdef func():print("我是黄同学")# 创建窗口:实例化一个窗口对象。
root = Tk()# 窗口大小
root.geometry("600x450+374+182")#  窗口标题
root.title("我的个性签名设计")# 添加标签控件
label = Label(root,text="签名:",font=("宋体",25),fg="red")
# 定位
label.grid()# 添加输入框
entry = Entry(root,font=("宋体",25),fg="red")
entry.grid(row=0,column=1)# 添加点击按钮
button = Button(root,text="签名设计",font=("宋体",25),fg="blue",command=func)
button.grid(row=1,column=1)
"""
command=func表示调用最开始定义的func函数。
func函数一定要在这句代码之前,因为这里需要调用这个func函数。
"""
# 显示窗口
root.mainloop()

结果如下:

推荐文章

  • 李宏毅《机器学习》国语课程(2022)来了

  • 有人把吴恩达老师的机器学习和深度学习做成了中文版

  • 上瘾了,最近又给公司撸了一个可视化大屏(附源码)

  • 如此优雅,4款 Python 自动数据分析神器真香啊

  • 梳理半月有余,精心准备了17张知识思维导图,这次要讲清统计学

  • 香的很,整理了20份可视化大屏模板

技术交流

完整代码、数据获取,可以找我来要

技术交流、求职内推、干货汇总、与 3000+来自阿里、北大、清华、中科院、CMU、腾讯、百度等名校名企开发者互动交流~

目前开通了技术交流群,群友已超过3000人,添加时最好的备注方式为:来源+兴趣方向,方便找到志同道合的朋友

  • 方式①、发送如下图片至微信,长按识别,后台回复:加群;
  • 方式②、添加微信号:dkl88191,备注:来自CSDN
  • 方式③、微信搜索公众号:Python学习与数据挖掘,后台回复:加群

利用 Tkinter 打造专属图形化界面:设计签名相关推荐

  1. Python中Tkinter 图形化界面设计(详细教程)

    Python-Tkinter 图形化界面设计(详细教程) 一.图形化界面设计的基本理解 二. 窗体控件布局 2.1 根窗体呈现示例 2.2 tkinter 常用控件 2.2.1常用控件 2.2.2 控 ...

  2. Python + Tkinter 图形化界面设计1 —— 第一个图形化界面

    图形化界面设计的基本理解 Python自带了tkinter 模块,实质上是一种流行的面向对象的GUI工具包 TK 的Python编程接口,提供了快速便利地创建GUI应用程序的方法.其图像化编程的基本步 ...

  3. 零基础学Python【二十三、图形化界面设计 】(基础一篇全,欢迎认领)

    1.图形化界面设计的基本理解 当前流行的计算机桌面应用程序大多数为图形化用户界面(Graphic User Interface,GUI). 即通过鼠标对菜单.按钮等图形化元素触发指令,并从标签.对话框 ...

  4. Python 图形化界面设计

    1.图形化界面设计的基本理解 当前流行的计算机桌面应用程序大多数为图形化用户界面(Graphic User Interface,GUI),即通过鼠标对菜单.按钮等图形化元素触发指令,并从标签.对话框等 ...

  5. Python-Tkinter图形化界面设计(详细教程 )

    原文链接:https://www.jianshu.com/p/91844c5bca78 声明:本篇文章为转载自https://www.jianshu.com/p/91844c5bca78,在原作者的基 ...

  6. Python-Tkinter图形化界面设计

    综合了以下的文章: 转载自:https://www.cnblogs.com/shwee/p/9427975.html 转载自:https://www.jianshu.com/p/91844c5bca7 ...

  7. Java图形化界面设计——容器(JFrame)

    Java图形化界面设计--容器(JFrame) 程序是为了方便用户使用的,因此实现图形化界面的程序编写是所有编程语言发展的必然趋势,在命令提示符下运行的程序可以让我们了解java程序的基本知识体系结构 ...

  8. 图形化界面设计软件简要介绍

    图形化界面设计软件简要介绍 [摘要]:面向使用者的系统工程设计,其目的是要准确.快速地在设计者和使用者之间传递信息和实现功能,也是优化产品性能来适应大众的操作能力,减轻使用者的认知负担.成功的系统工程 ...

  9. java 网格布局管理器,Java图形化界面设计——布局管理器之GridLayout(网格布局)...

    网格布局特点: l  使容器中的各组件呈M行×N列的网格状分布. l  网格每列宽度相同,等于容器的宽度除以网格的列数. l  网格每行高度相同,等于容器的高度除以网格的行数. l  各组件的排列方式 ...

最新文章

  1. 【线性规划与网络流24题】孤岛营救问题 分层图
  2. 如何在Linux中安装和使用Silver Searcher(程序员的代码搜索工具)
  3. 计算机网络技术发源于什么,计算机网络基础试题和答案
  4. 数论 欧几里得与扩展欧几里得
  5. k8s管理java项目_Kubernetes集群部署项目-部署Java项目(推送镜像
  6. k8s系统架构图(二)
  7. 消息中间件的技术选型心得-RabbitMQ ActiveMQ和ZeroMQ
  8. 从程序员到项目经理(五):程序员加油站 -- 不是人人都懂的学习要点
  9. NGINX 笔记 - GeoIP 限制策略配置
  10. LaTex数学符号表(数学中最常用的所有符号)
  11. Java程序员面试常见问题
  12. gmx genion命令
  13. 第四讲:学习理论(Learning Theory)
  14. 我37岁,从互联网大厂跳槽到国企后,发现没有一劳永逸的工作。。。
  15. Jira Seraph 中的身份验证绕过漏洞(CVE-2022-0540)
  16. ppt怎么修改页面布局
  17. 计算机没有游戏客户端程序咋办,电脑开始菜单游戏不见了怎么办
  18. 双硫脲改性Zr-MOF吸附材料|聚多巴胺(PDA)改性MOF-5|羧酸改性的UiO-66(Zr)膜|有机骨架材料的定制技术
  19. 医疗器械答疑解惑篇之二
  20. TcpListener和TcpClient传输文件

热门文章

  1. 谨以此献给1980~1989出生的人
  2. 买电脑时,独显和集显到底有什么区别呢?
  3. 201703-2学生排队
  4. linux的vi编辑器课件,linux课件--第三章+文本编辑器vi.ppt
  5. 学习人工智能有哪些难点,有哪些常见的错误或误区需要避免?
  6. 工业4G组网方案:异地分支机构实现专用局域网!
  7. 相关性检验之Pearson系数及python实现
  8. webpack bulid后时,网页白屏,报错:导入的资源文件路径不对
  9. 实现背景动态化android,Android TV 动态设置背景的高斯模糊
  10. 携两位美女程序媛和多位大厂大佬,送一台 iPad!