第10天 | 25天学会wxPython,事件处理
ztj100 2025-03-24 22:45 4 浏览 0 评论
事件,就是程序在运行中发生的事儿,桌面应用软件都是事件驱动的。事件可以是用户的操作,如鼠标点击或按键按下,也可以由系统产生,如定时关机。事件会触发相应的行为,即事件函数。
程序员的工作就是定义事件函数,以及绑定事件和事件函数之间的关联关系,从而达到对事件处理的目的。
10.1 事件绑定
在wxPython中实现事件功能,有3个步骤,分别是:定义事件处理函数、选择事件类型(如wx.EVT_COLSE)、用Bind方法进行绑定。Bind的语法为:
Bind(event, handler, source=None, id=wx.ID_ANY, id2=wx.ID_ANY)
event为事件类型,如wx.EVT_COLSE, handler 指定了该事件所绑定的处理函数。 如果想区分来自不同组件,可用source参数或指定不同的id;如果将一个处理函数绑定至一多个组件id, 可以使用参数id2进一步区分。
Bind()方法在 EvtHandler 类定义, 而wx.Window类继承于EvtHandler类,所有大多数继承于wx.Window的组件,都有事件绑定方法Bind()。
程序清单:event.py
import wx
# 继承Frame
class Event(wx.Frame):
# 自定义id号
ID_CLEAR_BTN = 10001
ID_CLOSE_BTN = 10002
def __init__(self, *args, **kwargs):
super(Event, self).__init__(*args, **kwargs)
# 初始化窗口UI
self.init_ui()
def init_ui(self):
gbs = wx.GridBagSizer(5, 5)
self.content_text = wx.TextCtrl(self, style=wx.TE_MULTILINE)
gbs.Add(self.content_text, pos=(0, 0), span=(1, 4), flag=wx.EXPAND)
gbs.AddGrowableRow(0)
gbs.AddGrowableCol(1)
# 按钮
copy_btn = wx.Button(self, id=wx.ID_COPY, label="复制")
paste_btn = wx.Button(self, label="粘贴")
clear_btn = wx.Button(self, id=self.ID_CLEAR_BTN, label="清空")
exit_btn = wx.Button(self, id=self.ID_CLOSE_BTN, label="关闭")
gbs.Add(copy_btn, pos=(1, 0), flag=wx.ALL, border=10)
gbs.Add(paste_btn, pos=(1, 1), flag=wx.ALL, border=10)
gbs.Add(clear_btn, pos=(1, 2), flag=wx.ALL, border=10)
gbs.Add(exit_btn, pos=(1, 3), flag=wx.ALL, border=10)
# 用id(复制按钮)绑定事件
self.Bind(wx.EVT_BUTTON, self.copy, id=wx.ID_COPY)
# 绑定事件源(粘贴按钮)
self.Bind(wx.EVT_BUTTON, self.paste, paste_btn)
# 绑定到同一个事件方法
self.Bind(wx.EVT_BUTTON, self.clear, clear_btn)
self.Bind(wx.EVT_BUTTON, self.clear, id=self.ID_CLOSE_BTN)
self.SetSizer(gbs)
self.SetSize(900, 500)
self.SetTitle("事件处理")
self.Centre()
self.Show(True)
# 复制内容
def copy(self, e):
clip_data = wx.TextDataObject()
clip_data.SetText(self.content_text.GetValue())
wx.TheClipboard.Open()
wx.TheClipboard.SetData(clip_data)
wx.TheClipboard.Close()
# 粘贴内容到文本框中
def paste(self, e):
success = False
clip_data = wx.TextDataObject()
if wx.TheClipboard.Open():
# 从剪贴板得到数据
success = wx.TheClipboard.GetData(clip_data)
wx.TheClipboard.Close()
if success: # 文本内容粘贴到文本输入框中
self.content_text.SetValue(clip_data.GetText())
# 用id区分事件源
def clear(self, e):
# 匹配清空按钮
if self.ID_CLEAR_BTN == e.GetId():
self.content_text.SetValue("")
else: # 匹配退出按钮
self.Close()
def main():
app = wx.App(False)
Event(None)
app.MainLoop()
if __name__ == "__main__":
main()
运行程序之后,弹出的窗口如下:
不同的组件,用Bind()方法绑定同到一个事件处理函数时,可通过GetId()方法进行区别。wxPython中使用剪贴板存取文本数据,使用wx.TextDataObject()即可。
好了,事件处理的内容就说到这了,关注我,下一节更精彩。
码字不易,你的关注和转发是对我最大的鼓励,谢谢!
一个当了10年技术总监的老家伙,分享多年的编程经验。想学编程的朋友,关注我,你就赚到了。我正在分享Python、前端、Java和App方面的干货了。赶紧来围观啊!!!
相关推荐
- 7款主流sql工具大盘点!(sqlyog工具)
-
I:DataGripDataGrip,是大名鼎鼎的JetBrains公司出品的,就是那个出品IntellijIDEA的公司。优点:提供多数据库驱动拥有智能的上下文敏感和编码语法提示...
- nativcat for mysql软件(mysql免费下载)
-
NavicatforMySQL软件介绍基本信息NavicatforMySQL是一款专门针对MySQL数据库研发推出的数据库管理工具,也可用于管理和开发MariaDB数据库,是一套管理和开发My...
- 请注意了! mysql 可以连接 oceanbase
-
各位好,这回出差有个收获,接触到了oceanbase数据库,之前比较多的是mysql和oracle,这次现场要求不可以使用mysql数据库,临时现场调换数据库,再加上时间比较紧急,初步...
- 群晖NAS安装MySQL数据库及phpMyAdmin实现远程管理本地数据库
-
前言本文主要介绍如何在群晖NAS安装MySQL与数据库管理软件phpMyAdmin,并结合cpolar内网穿透工具配置公网地址,实现异地远程访问本地部署的phpMyAdmin详细流程。...
- 一张图说清楚 SQL JOINS 联接查询
-
在计算机领域,数据库一直被誉为是基础软件皇冠上的明珠。程序猿们日常也是调侃自己是只会CURD增删查改打螺丝的无情机器,无论再高大上的软件,只要是持久化到数据库,CRUD操作的工具就是SQL了。...
- 10个优秀的MySQL管理工具,都是大佬们的珍藏
-
Mysql开源、体积小、速度快、成本低、安全性高,目前在全球中小型网站中被广泛应用。今天给大家介绍10个优秀的MySQL管理工具,都是大佬们的珍藏,对你有用的话,可以收藏转发。1、Induction...
- 2022 年 11 大 MYSQL 监控工具「含开源」
-
数据库监控是应用程序性能监控中的关键组件。除了应用程序代码问题外,数据库问题是用户体验不佳的最常见原因之一。MySQL是企业广泛采用的最流行的开源DBMS之一。...
- 你用了吗?DBA必备的15款MySQL管理工具
-
如今,Web应用程序的响应速度是成功的关键法宝之一。它与用户互动,用户对网站的看法,甚至谷歌网站排名情况都有着密不可分的关系。数据库性能是响应速度最重要的因素之一,一旦出错,所有程序都将会宕机。工欲善...
- MySQL 数据同步神器 - Canal 入门篇
-
前言想必做过商品服务都是将商品相关的信息和价格保存在数据库中,例如...
- 推荐-轻量级-实用mysql客户端链接工具-HeiDiSQL
-
作为程序员,mysql的客户端链接工具我们可是再熟悉不过来了,都想使用一款比较方便功能齐全的数据库工具,目前比较流行的sqlyoung,navicat等等,sqlyoung和navicat需要破解,开...
- MySQL 中的 CROSS JOIN:强大的连接工具
-
CROSSJOIN在MySQL里是一种挺特别的连接操作,它能弄出连接表的笛卡尔积。这就是说,要是表A有m行,表B有n行,那ACROSSJOINB的结果就会有m*n...
- Navicat用久了试试这个炫酷的mysql连接工具,如丝滑般柔顺
-
背景web开发者都知道,数据对我们来说是最重要的,所有的curd都是针对于数据库。连接MySQL我们通常都是用Navicat,但是每次用都需要破解,并且感觉经常卡顿,并且提示功能感觉不准确,有没有更好...
- pandas筛选数据的20种高级用法(pandas dataframe筛选)
-
什么是Pandas库?作用是什么?Pandas库在数据处理和分析中具有广泛的应用,主要包括以下几个方面...
- 二文进阶Pandas数据可视化(python数据可视化pyecharts)
-
欢迎来到Pandas的进阶高级教程!在这篇教程中,我们将深入学习Pandas的高级功能和技巧,帮助你更加熟练地处理和分析数据。1.数据合并与连接在实际数据分析中,我们常常需要将多个数据集合并或连接在...
你 发表评论:
欢迎- 一周热门
- 最近发表
- 标签列表
-
- idea eval reset (50)
- vue dispatch (70)
- update canceled (42)
- order by asc (53)
- spring gateway (67)
- 简单代码编程 贪吃蛇 (40)
- transforms.resize (33)
- redisson trylock (35)
- 卸载node (35)
- np.reshape (33)
- torch.arange (34)
- node卸载 (33)
- npm 源 (35)
- vue3 deep (35)
- win10 ssh (35)
- exceptionininitializererror (33)
- vue foreach (34)
- idea设置编码为utf8 (35)
- vue 数组添加元素 (34)
- std find (34)
- tablefield注解用途 (35)
- python str转json (34)
- java websocket客户端 (34)
- tensor.view (34)
- java jackson (34)