当前位置: 首页 > news >正文

tkinter控件教程使用说明(三)

这篇tkinter控件使用教程是最后一

一、TreeView

属性/事件描述代码实例
columns列名,用于设置树形视图的列tree["columns"] = ("姓名", "年龄", "性别")
column列的属性,包括列名、宽度等tree.column("姓名", width=100)
heading表头的属性,包括表头名称、文本等tree.heading("姓名", text="姓名")
insert插入数据的方法,包括父节点、位置、文本、值等参数tree.insert("", 0, text="行1", values=("张三", "25", "男"))
bind绑定事件的方法,包括事件名称和处理函数tree.bind("<<TreeviewSelect>>", on_select)
<>当用户选择树形视图中的某个项目时触发的事件def on_select(event):

以下是Tkinter Treeview的所有事件:

事件名称描述
TreeviewSelect当用户选择树形视图中的某个项目时触发的事件
TreeviewOpen当用户展开或折叠树形视图中的某个节点时触发的事件
TreeviewClose当用户关闭树形视图中的某个节点时触发的事件
TreeviewBell当用户尝试在树形视图中插入数据时,如果该数据已经存在,则触发此事件
TreeviewEdit当用户编辑树形视图中的某个项目时触发的事件
TreeviewInplaceEdit当用户使用“就地编辑”功能编辑树形视图中的某个项目时触发的事件
TreeviewBeginDrag当用户开始拖动树形视图中的某个项目时触发的事件
TreeviewEndDrag当用户结束拖动树形视图中的某个项目时触发的事件
TreeviewDrag当用户正在拖动树形视图中的某个项目时触发的事件
TreeviewDelete当用户删除树形视图中的某个项目时触发的事件
TreeviewRefresh当树形视图的数据源发生变化时触发的事件
TreeviewScroll当用户滚动树形视图时触发的事件
TreeviewSort当用户对树形视图进行排序时触发的事件
TreeviewItemInvoke当用户双击树形视图中的某个项目时触发的事件
TreeviewItemExpand当用户展开树形视图中的某个节点时触发的事件
TreeviewItemCollapse当用户折叠树形视图中的某个节点时触发的事件
TreeviewItemFocusIn当树形视图中的某个项目获得焦点时触发的事件
TreeviewItemFocusOut当树形视图中的某个项目失去焦点时触发的事件
TreeviewItemSelection当树形视图中的某个项目被选中或取消选中时触发的事件
TreeviewItemSelectionClear当树形视图中的某个项目的选中状态被清除时触发的事件
TreeviewItemSelectionSet当树形视图中的某个项目被选中时触发的事件
TreeviewItemSelectionToggle当树形视图中的某个项目的选中状态被切换时触发的事件
TreeviewItemVisible当树形视图中的某个项目变得可见时触发的事件
TreeviewItemHidden当树形视图中的某个项目变得不可见时触发的事件
TreeviewItemPrevVisible当树形视图中的某个项目的前一个项目变得可见时触发的事件
TreeviewItemNextVisible当树形视图中的某个项目的后一个项目变得可见时触发的事件
TreeviewItemActivate当树形视图中的某个项目被激活时触发的事件

下面是treeview调用的简单代码实例:


import tkinter as tk
from tkinter import ttkdef on_select(event):item = tree.selection()[0]print("你选择了", tree.item(item, "text"))root = tk.Tk()
root.title("Treeview 示例")tree = ttk.Treeview(root, columns=("名称", "类型"), show="headings")
tree.heading("名称", text="名称")
tree.heading("类型", text="类型")
tree.column("名称", width=100)
tree.column("类型", width=100)tree.insert("", "end", text="文件夹1", values=("文件夹1", "文件夹"))
tree.insert("", "end", text="文件1", values=("文件1", "文件"))
tree.insert("", "end", text="文件2", values=("文件2", "文件"))tree.bind("<<TreeviewSelect>>", on_select)
tree.pack()root.mainloop()

二、消息框MessageBox

消息框对于每种GUI都是不可缺少的,就算是做个游戏也是需要的比如pygame就有。

属性/事件描述代码实例
title消息框的标题messagebox.showinfo(title="提示")
message消息框的内容messagebox.showinfo(message="这是一个提示")
icon消息框的图标messagebox.showinfo(icon="error")
type消息框的类型messagebox.showinfo(type="warning")
parent消息框的父窗口messagebox.showinfo(parent=root)
detail消息框的详细信息messagebox.showinfo(detail="这是详细信息")
default消息框的默认按钮messagebox.showinfo(default="ok")
cancel消息框的取消按钮messagebox.showinfo(cancel="cancel")
buttons消息框的按钮列表messagebox.showinfo(buttons=("yes", "no"))
command消息框的回调函数messagebox.showinfo(command=callback)

以下是一些使用MessageBox的代码实例:

import tkinter as tk
from tkinter import messageboxdef callback():print("点击了确定按钮")root = tk.Tk()# 显示一个信息框
messagebox.showinfo(title="提示", message="这是一个提示", icon="info", type="info", parent=root, detail="这是详细信息", default="ok", cancel="cancel", buttons=("yes", "no"), command=callback)# 显示一个警告框
messagebox.showwarning(title="警告", message="这是一个警告", icon="warning", type="warning", parent=root, detail="这是详细信息", default="ok", cancel="cancel", buttons=("yes", "no"), command=callback)# 显示一个错误框
messagebox.showerror(title="错误", message="这是一个错误", icon="error", type="error", parent=root, detail="这是详细信息", default="ok", cancel="cancel", buttons=("yes", "no"), command=callback)# 显示一个询问框
result = messagebox.askquestion(title="询问", message="这是一个询问", icon="question", type="question", parent=root, detail="这是详细信息", default="yes", cancel="no", buttons=("yes", "no"), command=callback)
if result == "yes":print("选择了是")
else:print("选择了否")root.mainloop()

三、spinbox

Spinbox用于创建一个带有上下箭头的输入框,用户可以通过点击箭头来增加或减少输入框中的值。它通常用于需要限制用户输入范围的场景,例如选择年龄、分数等。

属性/事件描述代码实例
from_Spinbox的最小值spinbox = Spinbox(from_=0, to=10)
toSpinbox的最大值spinbox = Spinbox(from_=0, to=10)
incrementSpinbox的增量spinbox = Spinbox(from_=0, to=10, increment=2)
valuesSpinbox的值列表spinbox = Spinbox(values=(0, 2, 4, 6, 8, 10))
wrapSpinbox是否循环spinbox = Spinbox(from_=0, to=10, wrap=True)
stateSpinbox的状态(normal或readonly)spinbox = Spinbox(state="readonly")
textvariableSpinbox的值绑定到变量spinbox = Spinbox(textvariable=var)
commandSpinbox的值改变时的回调函数spinbox = Spinbox(command=callback)

以下是一些使用Spinbox的代码实例:

import tkinter as tkdef callback():print("当前值为:", spinbox.get())root = tk.Tk()# 创建一个Spinbox,范围从0到10,增量为2
spinbox = tk.Spinbox(root, from_=0, to=10, increment=2)
spinbox.pack()# 创建一个Spinbox,值列表为(0, 2, 4, 6, 8, 10)
spinbox = tk.Spinbox(root, values=(0, 2, 4, 6, 8, 10))
spinbox.pack()# 创建一个Spinbox,范围从0到10,循环
spinbox = tk.Spinbox(root, from_=0, to=10, wrap=True)
spinbox.pack()# 创建一个Spinbox,状态为只读
spinbox = tk.Spinbox(root, state="readonly")
spinbox.pack()# 创建一个Spinbox,值绑定到变量
var = tk.StringVar()
spinbox = tk.Spinbox(root, textvariable=var)
spinbox.pack()# 创建一个Spinbox,值改变时的回调函数
spinbox = tk.Spinbox(root, command=callback)
spinbox.pack()root.mainloop()

四、Progressbar

Progressbar用于显示一个进度条,通常用于表示某个任务的完成进度。它通常用于需要长时间等待的场景,例如文件下载、数据处理等。

以下是一些使用Progressbar的代码实例:

import tkinter as tk
from tkinter import ttkroot = tk.Tk()# 创建一个Progressbar,范围从0到100
progressbar = ttk.Progressbar(root, orient="horizontal", length=200, mode="determinate")
progressbar.pack()# 设置Progressbar的值
progressbar["value"] = 50root.mainloop()
属性/事件描述代码实例
orientProgressbar的方向(horizontal或vertical)progressbar = ttk.Progressbar(root, orient="horizontal")
lengthProgressbar的长度progressbar = ttk.Progressbar(root, length=200)
modeProgressbar的模式(determinate或indeterminate)progressbar = ttk.Progressbar(root, mode="determinate")
valueProgressbar的当前值progressbar["value"] = 50
maximumProgressbar的最大值progressbar["maximum"] = 100
variableProgressbar的值变量progressbar["variable"] = progress_var
commandProgressbar的值改变时的回调函数progressbar["command"] = callback

五、PanedWindow

PanedWindow用于创建一个可分割的窗口,可以将多个子控件放置在不同的区域中。它通常用于需要将界面分成多个部分的场景,例如左侧导航栏、上下方框等。

以下是一些使用PanedWindow的代码实例:

import tkinter as tk
from tkinter import ttkroot = tk.Tk()# 创建一个PanedWindow
panedwindow = ttk.PanedWindow(root, orient="horizontal")
panedwindow.pack(fill="both", expand=True)# 添加两个子控件
frame1 = ttk.Frame(panedwindow, width=200, height=200, relief="sunken", borderwidth=2)
frame2 = ttk.Frame(panedwindow, width=200, height=200, relief="sunken", borderwidth=2)
panedwindow.add(frame1)
panedwindow.add(frame2)root.mainloop()
属性/事件描述代码实例
orientPanedWindow的方向(horizontal或vertical)panedwindow = ttk.PanedWindow(root, orient="horizontal")
firstsplitter是否显示第一个分隔条panedwindow["firstsplitter"] = False
sashrelief分隔条的样式(flat、groove、raised、ridge、solid或sunken)panedwindow["sashrelief"] = "groove"
sashwidth分隔条的宽度panedwindow["sashwidth"] = 5
sashpad分隔条与子控件之间的间距panedwindow["sashpad"] = 5
handlesize分隔条的大小panedwindow["handlesize"] = 10
handlepad分隔条与子控件之间的间距panedwindow["handlepad"] = 5
proxybackground代理背景颜色panedwindow["proxybackground"] = "red"
proxyborderwidth代理边框宽度panedwindow["proxyborderwidth"] = 2
proxyrelief代理边框样式panedwindow["proxyrelief"] = "groove"
proxywidth代理宽度panedwindow["proxywidth"] = 200
proxyheight代理高度panedwindow["proxyheight"] = 200

六、tkinter中控件的快捷键的实现方法

快捷键是我们编写软件的刚需,所以这里在最后一片博文简单介绍一下快捷键的代码编写。

import tkinter as tkdef clear_input(event=None):# 清除输入框内容的函数input_entry.delete(0, tk.END )def process_data():# 处理数据的函数input_text = input_entry.get()# 这里可以添加你的数据处理逻辑output_text = "Processed Data: " + input_textoutput_label.config(text=output_text)# 创建主窗口
root = tk.Tk()
root.title("General Engineering Tool")# 创建输入框
input_label = tk.Label(root, text="Input:")
input_label.pack()
input_entry = tk.Entry(root)
input_entry.pack()# 创建输出标签
output_label = tk.Label(root, text="")
output_label.pack()# 创建清除按钮,设置图标和文本对齐方式
clear_button = tk.Button(root, text="Clear", command=clear_input,  compound=tk.CENTER )
clear_button.pack()
root.bind('<Alt-e>', clear_input ) # 监听Alt+E快捷键
# 创建处理按钮
process_button = tk.Button(root, text="Process", command=process_data)
process_button.pack()# 运行主循环
root.mainloop()

相关文章:

tkinter控件教程使用说明(三)

这篇tkinter控件使用教程是最后一 一、TreeView 属性/事件描述代码实例columns列名&#xff0c;用于设置树形视图的列tree["columns"] ("姓名", "年龄", "性别")column列的属性&#xff0c;包括列名、宽度等tree.column("姓名…...

Electron 打包自定义NSIS脚本为安装向导增加自定义页面增加输入框

Electron 打包工具有很多&#xff0c;如Electron-build、 Electron Forge 等&#xff0c;这里使用Electron-build&#xff0c;而Electron-build使用了nsis组件来创建安装向导&#xff0c;默认情况nsis安装向导不能自定义安装向导界面&#xff0c;但是nsis提供了nsis脚本可以扩展…...

Idea2023创建Servlet项目

① Java EE 只是一个抽象的规范&#xff0c;具体实现称为应用服务器。 ② Java EE 只需要两个包 jsp-api.jar 和 servlet-api.jar&#xff0c;而这两个包是没有官方版本的。也就是说&#xff0c;Java 没有提供这两个包&#xff0c;只提供了一个规范。那么这两个包是谁提供的…...

Day57:WEB攻防-SSRF服务端请求Gopher伪协议无回显利用黑白盒挖掘业务功能点

目录 SSRF-原理&挖掘&利用&修复 SSRF无回显解决办法 SSRF漏洞挖掘 SSRF协议利用 http:// &#xff08;常用&#xff09; file:/// &#xff08;常用&#xff09; dict:// &#xff08;常用&#xff09; sftp:// ldap:// tftp:// gopher:// &#xff08;…...

【Qt】使用Qt实现Web服务器(十):前端基础

1、简述 本人对HTML元素不熟悉,利用QtWebApp加载静态页面来熟悉下HTML元素。 2、测试代码 # a)main中创建 HttpListener new HttpListener(listenerSettings,new RequestMapper(&app),&app);#...

使用vuepress搭建个人的博客(一):基础构建

前言 vuepress是一个构建静态资源网站的库 地址:VuePress 一般来说,这个框架非常适合构建个人技术博客,你只需要把自己写好的markdown文档准备好,完成对应的配置就可以了 搭建 初始化和引入 创建文件夹press-blog npm初始化 npm init 引入包 npm install -D vuepress…...

ArcGIS Pro导出布局时去除在线地图水印

目录 一、背景 二、解决方法 一、背景 在ArcGIS Pro中经常会用到软件自带的在线地图&#xff0c;但是在导出布局时&#xff0c;图片右下方会自带地图的水印 二、解决方法 解决方法&#xff1a;添加动态文本--服务图层制作者名单&#xff0c;然后在布局中选定位置添加 在状…...

启动mysql

删除C:\Program Files (x86)\MySQL\MySQL Server 5.7这个路径下的data文件夹&#xff0c;这个很难删除&#xff0c;因为一开机&#xff0c;mysql的某些服务就启动了&#xff0c;每次重新启动mysql之前&#xff0c;都要删除这个文件夹 因为这个文件夹在后端执行一些我们看不到的…...

C++实现二叉搜索树的增删查改(非递归玩法)

文章目录 一、二叉搜索树的概念结构和时间复杂度二、二叉搜索树的插入三、二叉搜索树的查找四、二叉搜索树的删除&#xff08;最麻烦&#xff0c;情况最多&#xff0c;一一分析&#xff09;3.1首先我们按照一般情况下写&#xff0c;不考虑特殊情况下4.1.1左为空的情况&#xff…...

软件架构复用

1.软件架构复用的定义及分类 软件产品线是指一组软件密集型系统&#xff0c;它们共享一个公共的、可管理的特性集&#xff0c;满足某个特定市场或任务的具体需要&#xff0c;是以规定的方式用公共的核心资产集成开发出来的。即围绕核心资产库进行管理、复用、集成新的系统。核心…...

【初阶数据结构】——leetcode:160. 相交链表

文章目录 1. 题目介绍2. 思路1&#xff1a;暴力求解算法思想代码实现 3. 思路2&#xff1a;快慢指针算法思想代码实现 1. 题目介绍 链接: link 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点&…...

【Go】goroutine并发常见的变量覆盖案例

越过山丘 遇见六十岁的我 拄着一根白手杖 在听鸟儿歌唱 我问他幸福与否 他笑着摆了摆手 在他身边围绕着一群 当年流放归来的朋友 他说你不必挽留 爱是一个人的等候 等到房顶开出了花 这里就是天下 总有人幸福白头 总有人哭着分手 无论相遇还是不相遇 都是献给岁月的序曲 …...

基于SSM+Jsp+Mysql的快递管理系统

开发语言&#xff1a;Java框架&#xff1a;ssm技术&#xff1a;JSPJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包…...

如何动态往Spring容器注册/移除bean?

几个关键点需要知道 本文不谈原理&#xff0c;直接上实战。 几个关键点&#xff1a;如何拿到Spring上下文来创建bean或移除bean&#xff1f;如何准备构建bean所需的BeanDefinition&#xff1f; 第一问&#xff1a;可注入bean工厂org.springframework.beans.factory.support.…...

C语言交换二进制位的奇数偶数位

基本思路 我们要先把想要交换的数的二进制位给写出来假如交换13的二进制位&#xff0c;13的二进制位是 0000 0000 0000 0000 0000 0000 0000 1101然后写出偶数位的二进制数&#xff08;偶数位是1的&#xff09; 1010 1010 1010 1010 1010 1010 1010 1010然后写出奇数位的二进…...

爬虫实战三、PyCharm搭建Scrapy开发调试环境

#一、环境准备 Python开发环境以及Scrapy框架安装&#xff0c;参考&#xff1a;爬虫实战一、Scrapy开发环境&#xff08;Win10Anaconda&#xff09;搭建 PyCharm安装和破解&#xff0c;参考&#xff1a;爬虫实战二、2019年PyCharm安装&#xff08;激活到2100年&#xff09; …...

2012年认证杯SPSSPRO杯数学建模C题(第一阶段)碎片化趋势下的奥运会商业模式全过程文档及程序

2012年认证杯SPSSPRO杯数学建模 C题 碎片化趋势下的奥运会商业模式 原题再现&#xff1a; 从 1984 年的美国洛杉矶奥运会开始&#xff0c;奥运会就不在成为一个“非卖品”&#xff0c;它在向观众诠释更高更快更强的体育精神的同时&#xff0c;也在攫取着巨大的商业价值&#…...

【Next.js】连接 MongoDB 实现基本的接口

【Next.js】连接 MongoDB 实现基本的接口 什么是 MongoDB MongoDB 是由C语言编写的&#xff0c;是一个基于分布式文件存储的开源数据库系统。在高负载的情况下&#xff0c;添加更多的节点&#xff0c;可以保证服务器性能。MongoDB 旨在为WEB应用提供可扩展的高性能数据存储解…...

中值滤波算法与SSE2指令集并行优化

中值滤波算法是经典图像处理中极为常见的操作,一般我们通过调用OpenCV或者是Matlab直接进行使用,以至于有种它本来就很容易实现且速度很快的错觉。近来用到中值滤波算法,因为不想用到OpenCV库或者Matlab而对其实现研究了一番,才发现其中有很多值得注意的细节。下面我们结合…...

2012年认证杯SPSSPRO杯数学建模B题(第二阶段)节能减排全过程文档及程序

2012年认证杯SPSSPRO杯数学建模 节能减排、抑制全球气候变暖 B题 白屋顶计划 原题再现&#xff1a; 第二阶段问题   虽然环境学家对地球环境温度的改变有许多种不同观点&#xff0c;但大多数科学家可以达成一个基本的共识&#xff1a;近年来人类的活动&#xff0c;尤指二氧…...

简易版抽奖活动的设计技术方案

1.前言 本技术方案旨在设计一套完整且可靠的抽奖活动逻辑,确保抽奖活动能够公平、公正、公开地进行,同时满足高并发访问、数据安全存储与高效处理等需求,为用户提供流畅的抽奖体验,助力业务顺利开展。本方案将涵盖抽奖活动的整体架构设计、核心流程逻辑、关键功能实现以及…...

MFC内存泄露

1、泄露代码示例 void X::SetApplicationBtn() {CMFCRibbonApplicationButton* pBtn GetApplicationButton();// 获取 Ribbon Bar 指针// 创建自定义按钮CCustomRibbonAppButton* pCustomButton new CCustomRibbonAppButton();pCustomButton->SetImage(IDB_BITMAP_Jdp26)…...

uniapp微信小程序视频实时流+pc端预览方案

方案类型技术实现是否免费优点缺点适用场景延迟范围开发复杂度​WebSocket图片帧​定时拍照Base64传输✅ 完全免费无需服务器 纯前端实现高延迟高流量 帧率极低个人demo测试 超低频监控500ms-2s⭐⭐​RTMP推流​TRTC/即构SDK推流❌ 付费方案 &#xff08;部分有免费额度&#x…...

(转)什么是DockerCompose?它有什么作用?

一、什么是DockerCompose? DockerCompose可以基于Compose文件帮我们快速的部署分布式应用&#xff0c;而无需手动一个个创建和运行容器。 Compose文件是一个文本文件&#xff0c;通过指令定义集群中的每个容器如何运行。 DockerCompose就是把DockerFile转换成指令去运行。 …...

JVM暂停(Stop-The-World,STW)的原因分类及对应排查方案

JVM暂停(Stop-The-World,STW)的完整原因分类及对应排查方案,结合JVM运行机制和常见故障场景整理而成: 一、GC相关暂停​​ 1. ​​安全点(Safepoint)阻塞​​ ​​现象​​:JVM暂停但无GC日志,日志显示No GCs detected。​​原因​​:JVM等待所有线程进入安全点(如…...

rnn判断string中第一次出现a的下标

# coding:utf8 import torch import torch.nn as nn import numpy as np import random import json""" 基于pytorch的网络编写 实现一个RNN网络完成多分类任务 判断字符 a 第一次出现在字符串中的位置 """class TorchModel(nn.Module):def __in…...

安全突围:重塑内生安全体系:齐向东在2025年BCS大会的演讲

文章目录 前言第一部分&#xff1a;体系力量是突围之钥第一重困境是体系思想落地不畅。第二重困境是大小体系融合瓶颈。第三重困境是“小体系”运营梗阻。 第二部分&#xff1a;体系矛盾是突围之障一是数据孤岛的障碍。二是投入不足的障碍。三是新旧兼容难的障碍。 第三部分&am…...

宇树科技,改名了!

提到国内具身智能和机器人领域的代表企业&#xff0c;那宇树科技&#xff08;Unitree&#xff09;必须名列其榜。 最近&#xff0c;宇树科技的一项新变动消息在业界引发了不少关注和讨论&#xff0c;即&#xff1a; 宇树向其合作伙伴发布了一封公司名称变更函称&#xff0c;因…...

第7篇:中间件全链路监控与 SQL 性能分析实践

7.1 章节导读 在构建数据库中间件的过程中&#xff0c;可观测性 和 性能分析 是保障系统稳定性与可维护性的核心能力。 特别是在复杂分布式场景中&#xff0c;必须做到&#xff1a; &#x1f50d; 追踪每一条 SQL 的生命周期&#xff08;从入口到数据库执行&#xff09;&#…...

uniapp 小程序 学习(一)

利用Hbuilder 创建项目 运行到内置浏览器看效果 下载微信小程序 安装到Hbuilder 下载地址 &#xff1a;开发者工具默认安装 设置服务端口号 在Hbuilder中设置微信小程序 配置 找到运行设置&#xff0c;将微信开发者工具放入到Hbuilder中&#xff0c; 打开后出现 如下 bug 解…...