python中wx模块的具体使用方法


Posted in Python onMay 15, 2020

wx包中的方法都是以大写字母开头的,而这和Python的习惯是相反的。

本节介绍如何创建python程序的图形用户界面(GUI),也就是那些带有按钮和文本框的窗口。这里介绍wxPython :

下载地址:http://www.wxpython.org/download.php

根据自己的操作系统下载相应版本。

安装:

安装过程非常简单,以win7系统为例,点击下载的exe 文件,保持安装目录与本机的python目录一致就OK了。

创建并显示一个框架

import wx # 需要导入wx模块
app = wx.App()
win = wx.Frame(None)
win.Show()
app.MainLoop()

运行:

python中wx模块的具体使用方法

我们来创建一个文本编辑器,功能要求如下:

* 它可以打开给定文件名的文本文件;

* 它可以编辑文件文件

* 它可以保存文本文件

* 它可以正常退出程序

一,设置按钮位置

import wx
app = wx.App()
win = wx.Frame(None,title = "编辑器", size=(410,335))
win.Show()

loadButton = wx.Button(win, label = '打开',pos = (225,5),size = (80,25))
saveButton = wx.Button(win, label = '保存',pos = (315,5),size = (80,25))
filename = wx.TextCtrl(win, pos = (5,5),size = (210,25))
contents = wx.TextCtrl(win, pos = (5,35),size = (390,260), style = wx.TE_MULTILINE | wx.HSCROLL)
app.MainLoop()

运行:

 python中wx模块的具体使用方法

这里可能需要注意的是,控件(按钮,输入框)的位置和尺寸,位置和尺寸都包括一对数值:位置包括x 和y坐标,而尺寸包括宽和高。

代码比较简单,按钮控件(打开、保存)就不解释了。需要注意的是文本控件,默认的文本框(text field)就是一行可编译的文本,没有滚动条,为了创建文本区(text area)只要使用style参数调整风格,style 参数的值实际上是个整数,但不用直接指定,可以使用按位或运算符OR联合了wx.TE_MULTILINE来获取多行文件区,以及 wx.HSCROLL来获取水平滚动条。

二、智能的布局

尽管明确每个组件的几何位置很容易理解,但调整起来比较乏味。

import wx
app = wx.App()
win = wx.Frame(None,title = "编辑器", size=(410,335))
bkg = wx.Panel(win)

loadButton = wx.Button(bkg, label = '打开')
saveButton = wx.Button(bkg, label = '保存')
filename = wx.TextCtrl(bkg)
contents = wx.TextCtrl(bkg, style = wx.TE_MULTILINE | wx.HSCROLL)

hbox = wx.BoxSizer()
hbox.Add(filename, proportion =1, flag = wx.EXPAND)
hbox.Add(loadButton, proportion =0,flag = wx.LEFT, border = 5)
hbox.Add(saveButton, proportion =0,flag = wx.LEFT, border = 5)

vbox = wx.BoxSizer(wx.VERTICAL)
vbox.Add(hbox,proportion = 0,flag = wx.EXPAND | wx.ALL, border = 5)
vbox.Add(contents, proportion = 1,flag=wx.EXPAND | wx.LEFT | wx.BOTTOM | wx.RIGHT, border = 5)

bkg.SetSizer(vbox)
win.Show()
app.MainLoop()

运行这段代码,窗口会和上面的相同,但是使用了相对坐标而不是绝对坐标。

wx.BoxSizer的构造函数带有一个决定它是水平还是垂直的参数,默认为水平。

add方法有几个参数,proportion参数根据在窗口改变大小时所分配的空间设置比例。flag参数类似于构造函数中的style参数,可

二、添加事件处理

上面的界面做好了,但是我们点击按钮不起任何的作用。

在GUI术语中,用户执行的动作(比如 点击按钮)叫做事件。我们需要让程序注意这些事件并且作出反应。

假设写了一个负责打开文件的函数,并将其命令为load ,然后就可以像下面这样将函数作为loadButton的事件处理函数:

loadButton.Bind(wx.EVT_BUTTON, load)

让我们来完成剩下的工作,现在需要的就是两个事件处理函数:load(打开)和save(保存)。当事件被调用时,它会收到一个事件对象作为它唯一的参数,其中包括发生了什么事情的信息,但是在这里可以忽略这方法的事情,因为程序只关心点击时发生的事情。

def load(event):
  file = open(filename.GetValue())
  contents.SetValue(file.read())
  file.close()

上节刚刚学过文件的打开/读取,文件名使用filename对象GetValue方法获取。为了将文本引入文本区,只要使用contents.SetValue即可。

save函数和load类似,除了它需要写入(‘w'),以及用于文件处理部分的write方法,GetValue用于从文本区获得信息。

def save(event):
  file = open(filename.GetValue(),'w')
  file.write(contents.GetValue())
  file.close()

万事具备,将它们最终组装,内容如下:

import wx

def load(event):
  file = open(filename.GetValue())
  contents.SetValue(file.read())
  file.close()

def save(event):
  file = open(filename.GetValue(),'w')
  file.write(contents.GetValue())
  file.close()

app = wx.App()
win = wx.Frame(None,title = "编辑器", size=(410,335))
bkg = wx.Panel(win)

loadButton = wx.Button(bkg, label = '打开')
loadButton.Bind(wx.EVT_BUTTON,load)

saveButton = wx.Button(bkg, label = '保存')
saveButton.Bind(wx.EVT_BUTTON,save)

filename = wx.TextCtrl(bkg)
contents = wx.TextCtrl(bkg, style = wx.TE_MULTILINE | wx.HSCROLL)

hbox = wx.BoxSizer()
hbox.Add(filename, proportion =1, flag = wx.EXPAND)
hbox.Add(loadButton, proportion =0,flag = wx.LEFT, border = 5)
hbox.Add(saveButton, proportion =0,flag = wx.LEFT, border = 5)

vbox = wx.BoxSizer(wx.VERTICAL)
vbox.Add(hbox,proportion = 0,flag = wx.EXPAND | wx.ALL, border = 5)
vbox.Add(contents, proportion = 1,flag=wx.EXPAND | wx.LEFT | wx.BOTTOM | wx.RIGHT, border = 5)

bkg.SetSizer(vbox)
win.Show()
app.MainLoop()

运行:

python中wx模块的具体使用方法

下面玩转这个小程序步骤:

1、文本框输入aaa.txt 

2、文本区输入hello.world!

3、点击保存(不会有保存成功的提示,但它已经成功了)

4、关闭编辑器(只为了好玩),重新运行打开。

5、文件框输入aaa.txt ,点击“打开”按钮,上次编辑的内容(hello.world)在文本区出现了。

到此这篇关于python中wx模块的具体使用方法的文章就介绍到这了,更多相关python wx模块内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
python 简易计算器程序,代码就几行
Aug 29 Python
python翻译软件实现代码(使用google api完成)
Nov 26 Python
在Python的Flask框架下使用sqlalchemy库的简单教程
Apr 09 Python
给Python中的MySQLdb模块添加超时功能的教程
May 05 Python
python文件的md5加密方法
Apr 06 Python
利用Python实现颜色色值转换的小工具
Oct 27 Python
pandas 获取季度,月度,年度首尾日期的方法
Apr 11 Python
python自动生成model文件过程详解
Nov 02 Python
python__new__内置静态方法使用解析
Jan 07 Python
python的sys.path模块路径添加方式
Mar 09 Python
pycharm 代码自动补全的实现方法(图文)
Sep 18 Python
pytest配置文件pytest.ini的详细使用
Apr 17 Python
使用pymysql查询数据库,把结果保存为列表并获取指定元素下标实例
May 15 #Python
python随机模块random的22种函数(小结)
May 15 #Python
将pymysql获取到的数据类型是tuple转化为pandas方式
May 15 #Python
python 数据库查询返回list或tuple实例
May 15 #Python
Python基于gevent实现高并发代码实例
May 15 #Python
Django bulk_create()、update()与数据库事务的效率对比分析
May 15 #Python
Python实现aes加密解密多种方法解析
May 15 #Python
You might like
IP138 IP地址查询小偷实现代码
2010/02/15 PHP
带密匙的php加密解密示例分享
2014/01/29 PHP
php微信公众号开发之校园图书馆
2018/10/20 PHP
Google AJAX 搜索 API实现代码
2010/11/17 Javascript
网页整体变灰白色(兼容各浏览器)实例
2013/04/21 Javascript
javascript伸缩菜单栏实现代码分享
2015/11/12 Javascript
JavaScript表单验证实例之验证表单项是否为空
2016/01/10 Javascript
JavaScript tab选项卡插件实例代码
2016/02/23 Javascript
AngularJs bootstrap搭载前台框架——js控制部分
2016/09/01 Javascript
基于JavaScript实现屏幕滚动效果
2017/01/18 Javascript
vue2.0 axios跨域并渲染的问题解决方法
2018/03/08 Javascript
vue中倒计时组件的实例代码
2018/07/06 Javascript
vue实现简单的星级评分组件源码
2018/11/16 Javascript
Vue+Webpack完美整合富文本编辑器TinyMce的方法
2018/11/30 Javascript
谈谈React中的Render Props模式
2018/12/06 Javascript
node.js中Buffer缓冲器的原理与使用方法分析
2019/11/23 Javascript
JavaScript undefined及null区别实例解析
2020/07/21 Javascript
用Python代码来绘制彭罗斯点阵的教程
2015/04/03 Python
好的Python培训机构应该具备哪些条件
2018/05/23 Python
python实现机器学习之元线性回归
2018/09/06 Python
树莓派用python中的OpenCV输出USB摄像头画面
2019/06/22 Python
简单了解Python生成器是什么
2019/07/02 Python
python PyAutoGUI 模拟鼠标键盘操作和截屏功能
2019/08/04 Python
Pandas将列表(List)转换为数据框(Dataframe)
2020/04/24 Python
Python requests模块安装及使用教程图解
2020/06/30 Python
python爬虫智能翻页批量下载文件的实例详解
2021/02/02 Python
7款设计巧妙的css3飘带状3D立体效果的导航菜单和表单窗口
2013/02/04 HTML / CSS
英国50岁以上人群的交友网站:Ourtime
2018/03/28 全球购物
淘宝网店营销策划书
2014/01/11 职场文书
理财学专业自荐书
2014/06/28 职场文书
责任书格式范文
2014/07/28 职场文书
暑期培训心得体会
2014/09/02 职场文书
2014年宣传部个人工作总结
2014/12/06 职场文书
故宫导游词
2015/01/31 职场文书
Redis 操作多个数据库的配置的方法实现
2022/03/23 Redis
MongoDB支持的数据类型
2022/04/11 MongoDB