Python Tkinter入门教程(python tkinter模块)
liuian 2025-06-10 16:26 35 浏览
在 Python 中,Tkinter 是一个内置的图形用户界面(graphical user interfaces, aka GUI)库
无需额外安装即可使用。它提供了创建窗口、按钮、文本框、菜单等组件的功能,让你可以快速搭建桌面应用程序
1. 快速开始:创建一个“大黄猫吃小动物”文本显示窗口
import tkinter as tk #设置别名
from tkinter import font 导入字体
窗口 = tk.Tk() #创建一个主窗口对象
窗口.title("事件描述")
# 获取屏幕尺寸
屏幕宽度 = 窗口.winfo_screenwidth()
屏幕高度 = 窗口.winfo_screenheight()
# 设置窗口大小尺寸为黄金分割比,位置居中屏幕
窗口宽度 = 324
窗口高度 = 200
x坐标 = (屏幕宽度 - 窗口宽度) // 2
y坐标 = (屏幕高度 - 窗口高度) // 2
窗口.geometry(f"{窗口宽度}x{窗口高度}+{x坐标}+{y坐标}") # 使用geometry设置窗口大小和位置
# 创建字体对象,设置字体为Myriad Set Pro,大小为26,加粗
自定义字体 = font.Font(family="Myriad Set Pro", size=26, weight="bold")
标签 = tk.Label(窗口, text="大黄猫吃小动物", font=自定义字体) # 使用font参数设置字体
标签.place(relx=0.5, rely=0.5, anchor="center") # 使用place布局,将标签放置在窗口正中央,relxx'和'rely'参数表示相对于窗口的相对位置,'anchor'参数表示对齐方式
窗口.mainloop() # 让窗口保持显示并等待用户操作2. 常用组件
- Tkinter 提供了多种组件(a variety of components)(控件,widgets)用于构建界面(building interfaces)
- 如 Label、Button、Entry、Text、Checkbutton、Radiobutton、Scale 等
- 下面示例展示(demonstrate)几个常见组件的使用方式
2.1 标签与按钮
import tkinter as tk
# 点击按钮后,终端会输出“按钮已被点击”
def say_hello():
print("按钮已被点击")
窗口 = tk.Tk()
窗口.title("按钮测试")
提示语 = tk.Label(窗口, text="这是一个按钮")
提示语.pack()
# 创建一个按钮,点击后会执行say_hello函数
按钮 = tk.Button(窗口, text="快点我", command=say_hello)
按钮.pack()
窗口.mainloop()2.2 文本输入框 (Entry)
import tkinter as tk
def 获取输入():
大黄猫的输入 = 输入框.get() # 输入框.get()获取输入框中的内容
print(f"大黄猫输入的内容是: {大黄猫的输入}") #终端输出
窗口 = tk.Tk()
窗口.title("测试文本输入")
输入框 = tk.Entry(窗口)
输入框.pack()
# 添加一个按钮,点击时调用获取输入函数
按钮 = tk.Button(窗口, text="获取输入", command=获取输入)
按钮.pack()
窗口.mainloop()说明:示例中的变量"输入框"是为了便于理解而命名,实际运用中请替换为entry, "按钮"替换为btn, "窗口"替换为root
3. 布局管理器 (Layout Managers)
Tkinter 提供了三种主要的布局管理器:pack, grid, place。
3.1 pack
- 以顺序方式将组件排列在窗口中,常用 side 参数指定放置方向(top, bottom, left, right)。
import tkinter as tk
窗口 = tk.Tk()
tk.Label(窗口, text="顶部标签").pack(side="top")
tk.Label(窗口, text="底部标签").pack(side="bottom")
窗口.mainloop()3.2 grid
- 采用行列网格方式管理布局,常用 row、column 指定位置。
# 测试grid布局
import tkinter as tk
窗口 = tk.Tk()
tk.Label(窗口, text="标签1").grid(row=0, column=0) # 第一行第一列
tk.Label(窗口, text="标签2").grid(row=0, column=1) # 第一行第二列
窗口.mainloop()
#示例2
import tkinter as tk
窗口 = tk.Tk()
for 行 in range(2):
for 列 in range(2):
tk.Label(窗口, text=f"第 {行} 行, 第 {列} 列", borderwidth=2, relief="groove").grid(row=行, column=列, padx=5, pady=5)
窗口.mainloop()
# borderwidth 边框宽度, relief 边框样式,groove 3D 效果3.3 place
- 绝对定位布局,通过 x、y 指定位置。适合对精确像素定位有需求的场景,但一般不推荐使用。
(Places widgets at absolute coordinates, rarely used unless you need precise pixel control.)
4. 事件与回调 (Events & Callbacks)
在 Tkinter 中,可以通过事件绑定让组件对用户操作做出响应。比如鼠标点击、键盘输入等。
import tkinter as tk
def on_click(event):
print(f"鼠标点击位置: {event.x}, {event.y}")
窗口 = tk.Tk()
窗口.title("测试鼠标点击事件")
画布 = tk.Canvas(窗口, width=200, height=200, bg="lightblue") #Canvas是一个画布控件,用于绘制图形和显示文本
画布.bind("<Button-1>", on_click) # 绑定鼠标左键点击事件到on_click函数,"<Button-1>"表示鼠标左键点击事件
画布.pack()
窗口.mainloop()5. 项目案例:
5.1 简易计数器 (Mini Project: Counter)
import tkinter as tk
def 增加计数():
global 计数
计数 += 1
标签.config(text=str(计数))
窗口 = tk.Tk()
窗口.title("简易计数器")
计数 = 0
标签 = tk.Label(窗口, text=str(计数), font=("Arial", 24))
标签.pack(padx=20, pady=20)
按钮 = tk.Button(窗口, text="增加计数", command=增加计数)
按钮.pack()
窗口.mainloop()5.2 进度条示例
import tkinter as tk
def 开始进度():
for i in range(101):
进度条['value'] = i # 设置进度条的值
窗口.update_idletasks() # 更新窗口, 让进度条显示出来
time.sleep(0.05) # 模拟耗时操作
窗口 = tk.Tk()
窗口.title("进度条示例")
# 创建进度条,progressbar是进度条控件, orient是进度条的方向, length是进度条的长度, mode是进度条的模式
进度条 = ttk.Progressbar(窗口, orient="horizontal", length=300, mode="determinate")
进度条.pack(padx=20, pady=20)
开始按钮 = tk.Button(窗口, text="开始", command=开始进度)
开始按钮.pack()
窗口.mainloop()5.3 文件选择器
import tkinter as tk
from tkinter import filedialog # filedialog是一个对话框控件, 用于选择文件和文件夹
def 选择文件():
文件路径 = filedialog.askopenfilename(title="选择文件") # askopenfilename是一个对话框函数, 用于选择文件
if 文件路径:
标签.config(text=f"已选择文件: {文件路径}") # 标签.config是一个标签控件的方法, 用于设置标签的文本
窗口 = tk.Tk()
窗口.title("文件选择器")
标签 = tk.Label(窗口, text="点击按钮选择文件", width=50)
标签.pack(padx=20, pady=20)
按钮 = tk.Button(窗口, text="选择文件", command=选择文件)
按钮.pack()
窗口.mainloop()6. 小贴士与注意事项 (Tips & Caveats)
- 命名约定:常将主窗口命名为 root 或 window,方便阅读。
- 布局管理器:多种布局可组合使用,但同一容器(如一个 Frame)应使用同一种布局,以免冲突。(Use only one geometry manager in the same container to avoid conflicts.)
- 打包与发布:如果需要将 Tkinter 程序分发给不懂编程的用户,可使用如 pyinstaller 将脚本打包成可执行文件。(Use tools like pyinstaller to distribute your Tkinter apps as standalone executables.)
相关推荐
- 正在准备windows(正在准备windows请勿关机怎么办)
-
这个情况在使用华为电脑时可能会遇到。一般来说,这是因为电脑正在进行系统更新或者安装软件程序等操作,导致启动时间较长。如果电脑显示“正在准备Windows,请勿关闭电源”,则说明电脑正在进行系统更新。...
-
- 有win10安装包怎么装系统(win10安装包安装教程)
-
如果是原版ISO镜像,可以加载到虚拟光驱直接安装。如果是第三方更改的就需要启动盘。个人建议用U盘启动盘来安装。下载一个u盘启动盘程序(优启通、大白菜……),按照提示把它安装到U盘。启动盘制作完毕以后,启动电脑安快捷键选择U盘启动。进入pe后...
-
2026-01-14 16:37 liuian
- gho怎么变成iso文件(gho改成iso)
-
要将GHO转换为ISO,您需要使用GHO映像转换器软件。以下是执行此操作的步骤:1.下载和安装GHO映像转换器软件。2.运行转换器软件,并单击“打开”按钮。3.在弹出窗口中,选择要转换的GHO...
- office和visio安装顺序(office和visio怎么一起安装)
-
在某些情况下,安装Visio可能会发生与Office365冲突的问题。这是因为Visio和Office365具有不同的版本,可能会导致安装时出现错误或兼容性问题。为了避免这种冲突,...
- 电脑中病毒的原因(电脑中病毒正常吗)
-
电脑中毒的原因有以下几方面:1.网页被挂病毒。2.电脑裸奔,无防病毒软件。3.执行一些不安全的程序。4.U盘等不安全介质。5.电脑漏洞不及时补,被后台种毒。为了电脑不中病毒要注意以下几方面:1.更新系...
- 手机psd转换成jpg最简单方式
-
可以使用photoshop工具,方法如下:1、首先打开PS软件,然后选择自己需要的JPG格式的图片,在PS中打开。2、接下来先按快捷键“Ctrl+j”将图片复制出来,防止后面操作对原图片有损...
- win7提示激活码过期怎么办(win7激活已过期)
-
以win7为例,出现这样的问题原因分析:电脑的win7系统激活过又重新提示要激活的原因是因为微软对网络上的秘钥进行封杀所以导致我们激活无效。具体的解决方法:1、我们打开dos命令窗口,在创立中输入“s...
- 联想笔记本光驱驱动下载(联想电脑光驱驱动器在哪)
-
开机时进入BIOS,具体按什么牌子不同,按键也不同,开机有提示的,选择启动项,把光驱启动的顺序放到第一.按F10保存,重新启动就是光驱启动啦不需要设置光驱驱动,笔记本自带光驱驱动光驱是电脑的硬件设备,...
- win10装机必备实用软件(win10电脑装机必备软件)
-
1、office大部分的版本如office2007、office2000、office2011、office2013、office2016、office365等都支持win10。2、需要注意...
- 迅雷无法下载的链接用什么下载
-
1.可以使用其他下载工具代替迅雷。2.迅雷可能无法下载的原因有很多,比如网络问题、软件故障等。其他下载工具可以提供类似的功能,但可能具有更好的稳定性和兼容性。3.一些常见的替代迅雷的下载工具包括...
- apple官方网站(apple官方网站旗舰店)
-
1、首先打开浏览器,输入https://www.apple.com/;2、即可浏览苹果官网。 苹果公司(AppleInc.)是美国一家高科技公司。由史蒂夫·乔布斯、斯蒂夫·沃兹尼亚克和罗·韦恩(R...
- 哪些手机用鸿蒙系统(都什么手机能用鸿蒙系统)
-
截至目前,国内有以下几款手机品牌可以装鸿蒙系统:1.华为:华为Mate40系列、P40系列、Mate30系列、MatePadPro系列等。2.荣耀:荣耀V40、荣耀30系列、荣耀X10系列等...
- 手机u盘读不出来了怎么修复(手机u盘读取不出来)
-
1、手机不支持OTG功能,所以将U盘连接到手机后,手机无法识别U盘的内容,因此显示不了;这种情况只能换台支持OTG功能的手机来连接U盘才行。2、手机支持OTG功能,但是使用的OTG线质量有问题导致无法...
- 一周热门
-
-
飞牛OS入门安装遇到问题,如何解决?
-
如何在 iPhone 和 Android 上恢复已删除的抖音消息
-
Boost高性能并发无锁队列指南:boost::lockfree::queue
-
大模型手册: 保姆级用CherryStudio知识库
-
用什么工具在Win中查看8G大的log文件?
-
如何在 Windows 10 或 11 上通过命令行安装 Node.js 和 NPM
-
威联通NAS安装阿里云盘WebDAV服务并添加到Infuse
-
Trae IDE 如何与 GitHub 无缝对接?
-
idea插件之maven search(工欲善其事,必先利其器)
-
如何修改图片拍摄日期?快速修改图片拍摄日期的6种方法
-
- 最近发表
- 标签列表
-
- python判断字典是否为空 (50)
- crontab每周一执行 (48)
- aes和des区别 (43)
- bash脚本和shell脚本的区别 (35)
- canvas库 (33)
- dataframe筛选满足条件的行 (35)
- gitlab日志 (33)
- lua xpcall (36)
- blob转json (33)
- python判断是否在列表中 (34)
- python html转pdf (36)
- 安装指定版本npm (37)
- idea搜索jar包内容 (33)
- css鼠标悬停出现隐藏的文字 (34)
- linux nacos启动命令 (33)
- gitlab 日志 (36)
- adb pull (37)
- python判断元素在不在列表里 (34)
- python 字典删除元素 (34)
- vscode切换git分支 (35)
- python bytes转16进制 (35)
- grep前后几行 (34)
- hashmap转list (35)
- c++ 字符串查找 (35)
- mysql刷新权限 (34)
