PyQt编写Python GUI程序,舍弃Tkinter,来玩易语…
2018-07-12 07:43:22来源:博客园 阅读 ()
data:image/s3,"s3://crabby-images/f6a70/f6a70d4a33f0f5a1c5e969441789b7c3ae7b480e" alt="新老客户大回馈,云服务器低至5折"
data:image/s3,"s3://crabby-images/418e6/418e6eedb0b4c4ccd06f89579d9d382fd96b71c6" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
许多Python学习者在学习如何创建一个 GUI 应用的时候都感到十分的困难。其中最重要的原因是,他们不知道应该从何下手。大多数的教程都只有文字,但事实上仅仅依靠文字很难学会 GUI 编程,因为 GUI 应用大多数都是基于视觉上的。
data:image/s3,"s3://crabby-images/b9d38/b9d38f1f4ef56f93fe5a49bba4387f164c1fff10" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
这就是我们即将完成的东西:
data:image/s3,"s3://crabby-images/2e29d/2e29d9071e14872c4078e2af1687f3b22f1f7404" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
这是一个简单的 GUI 应用,根据输入的价格(price)和税率(tax rate),计算出最终的价格(final price)。
大多数的教程都试图直接通过Python代码来对 GUI 应用进行布局,但是这样做实在是很费劲。我们将要做的是利用优秀的 QT Designer 工具来对我们的应用进行布局。
data:image/s3,"s3://crabby-images/c1f6d/c1f6ddfaa0c4a986f4327282f14355a550097201" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
不要再用代码来设计界面了。所有的东西都将通过图形界面来搞定。
前提
如果你已经接受了我的建议并且安装了 Anaconda,你应该已经安装好了 PyQt4。如果没有的话,你需要从这里先下载它。
data:image/s3,"s3://crabby-images/50715/507156e66f65e6f1baa9637744dc25d2930e66eb" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
着手
打开 QT Designer。在弹出的窗口中,选择 Main Window,这样它会给你一个空白的画板。
data:image/s3,"s3://crabby-images/58bb8/58bb89a0d746586a0916796ef54a29b01ac67233" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
接下来在左侧选择Text Edit:
data:image/s3,"s3://crabby-images/c4e48/c4e48fa8b9a25b172a2efafc49da45cd836b10d4" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
将Text Edit 拖动到主窗口:
data:image/s3,"s3://crabby-images/cb3c8/cb3c801812c933988053205d3ba5219f51423df8" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
红圈框起来的部分就是定义这个对象的名字的地方。这个名字将是我们通过 Python 代码调用到这个对象的变量名。
data:image/s3,"s3://crabby-images/7cc5c/7cc5c0359e1b023eed24a9a31a62b1b00d1f2148" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
我将它取名为price_box,因为我们会在这里输入价格。然后我们需要给这个输入框添加一个 label(按钮),以便让用户更加清楚这个输入框的作用。
data:image/s3,"s3://crabby-images/23acc/23acc6a8dbc4517e9fb65ca8e6b518cfec3afd4b" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
我在上图中圈出了 label。把它拖动到主窗口当中来。
data:image/s3,"s3://crabby-images/8bd47/8bd47a806128464a4c255dc1d5bc383066a50c95" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/79687/79687b0c2e93ab6be778aabea1a30cfe7bb53ef1" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/7f08d/7f08df257f0da8fa5170f373fa9ce31e9d585bf4" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
对于税率(tax)输入框,我们会使用另外的一个东西。找到spin box:
data:image/s3,"s3://crabby-images/18c69/18c693e2df3a70b50863c47c2c2b97f43ab1c6b1" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
左侧用圈框起来的部分就是一个spin box。
data:image/s3,"s3://crabby-images/23317/2331791dd40ddf2d8674dedf7e8e06096274e807" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
请记住这将会是你在 Python 代码中调用它的时候会使用到的变量名。
data:image/s3,"s3://crabby-images/12291/122911c55724820c73b4729bd3b0aa0111fc6f54" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
我们可以为我们的spin box 设置一个默认值。我选择将其设置为 20:
data:image/s3,"s3://crabby-images/709b3/709b3044524bcda0aa893e48724f3931466ce754" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
你会发现我们也可以设置它的最小值和最大值。不过我并不打算去更改他们。
同样地,我会为它添加一个标签叫做Tax Rate。然后看看我们接下来会用到的圈起来的Push Button:
data:image/s3,"s3://crabby-images/e8be8/e8be807b33a292a08381ea7e69eeada3529e69cb" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
好的,现在选择Push Button 然后将其拖动到我们的窗口中来。
data:image/s3,"s3://crabby-images/0e389/0e3896cf48903caa9913b03c9ae75d4df9c6c944" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
这个按钮现在显示的是PushButton,这并不是一个很有意义的名字。
data:image/s3,"s3://crabby-images/f07e0/f07e094e68522d3213ba6fd061f75f09a1350d01" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/0a7ce/0a7cea74daf9f0c1e957a7cafe424fde099de260" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
然后,我们可以修改真正的显示文字列了:
data:image/s3,"s3://crabby-images/5709f/5709f35ad4597f76b8bfd99d20a4085f1d31db5f" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/36074/360740afcf6b885b19dc0462f6b88f8818fdcc5d" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/32611/32611c3f8ccfba851c8c38f9b7f0863e4415064b" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
如果你觉得需要的话,你可以添加一个大标题。这是一个简单的label box 并且将字体加大了。
data:image/s3,"s3://crabby-images/cef7d/cef7debb5eb822a1db9285fc778a683e531f1ccb" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
现在保存你的成果:
data:image/s3,"s3://crabby-images/069f9/069f9ba95a686c72ae75e423a1a4615d46fff5b3" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/6b164/6b1649ee09177577bbf7e128590c81bd0bff9756" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/1fbd4/1fbd43576c868d320162cdc604820452344cf220" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
编写python代码
Qt 代码是面向对象的,并且简单易学。所有我们添加的组件都是一个对象,并且都拥有自己的方法比如toPlainText()(用来读取输入框中的值)。这让它使用起来非常方便。
这些代码非常有用,每当你想要创建一个新的 PyQt 项目的时候,就在这段代码的基础上添加你自己的代码吧。
这段代码如下:
data:image/s3,"s3://crabby-images/e5ca5/e5ca52b0f6fa4146e3ad6a1c75ca78b2fc164b6c" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
注意第三行:
data:image/s3,"s3://crabby-images/c922f/c922f19f684abe8250d5cef5fc4852b92f253dcb" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
你需要在这里填入你先前创建的文件的地址。这个文件将会被内置的函数载入:
data:image/s3,"s3://crabby-images/598bd/598bd6d2651d4e358d7feed9ea9517bc1f391789" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
让我们大致地看一看这段代码:
data:image/s3,"s3://crabby-images/83d40/83d40efe389cd33a3251a543ec909caa9532e010" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/e7880/e788091e36a17e4d2d189628253a59f460a4c776" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/d4143/d4143877f624fd741db79fe6a8a161b1436aaa79" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
你不一定非得要了解这些代码的细节。你只需要在它的基础上继续开发就好了。
下载pyqt_skeleton.py 这个文件,并将它重命名为pyqt_first.py。这是因为我们不想去改动到源文件。然后要做的第一件事就是在代码中导入我们自己的 XML 文件,这个 XML 文件包含了我们的这个 GUI 信息。将下面的这一行:
data:image/s3,"s3://crabby-images/a62ec/a62ec25c66d488fa0d9111ba1c3f005310e32a0c" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
替换为
data:image/s3,"s3://crabby-images/d251e/d251e473545a916b60a5784e6f123e56e4b34e3e" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/0c420/0c420fa23b021852370b399b0345f3d5cab54542" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/30585/305854dfd9a741ef1076208eabdc89f24635cb73" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/3695c/3695cdffc591117d62f37c4266bb52e1da864b44" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
我们还没有实现这个函数。所以让我们动手开始写吧。
在MyApp 类中,添加另外一个函数。我们需要先看看整个函数,然后再去了解它的细节:
data:image/s3,"s3://crabby-images/95849/958495c5c4ba1052983ecb36abfd66b5a16becc7" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
好了,让我们一行一行的分析上面的代码。
我们现在要做两件事:读取价格和税率,然后计算最终的价格。好了开始吧。请记住,我们要通过我们设定的名字来调用这些组件(这就是我让你不要用默认的通用名称比如box1 的原因,否则的话我们在写代码的时候会很恼火)。
data:image/s3,"s3://crabby-images/57e08/57e0876e9d7e247d4f28d19841277ba89bb64ed0" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/4c9ff/4c9ff9902cbd58751d6ac78e036e88c6d7a9d445" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
Python
data:image/s3,"s3://crabby-images/1c065/1c065011c8e12a9f62ac23bb329097a4ce0a1190" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/09519/0951915977367502d46480d0c35b257205263972" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
最后运行我们写好的程序:
Python
python pyqt_first.py
data:image/s3,"s3://crabby-images/21e72/21e72acb83d7d407f2457b71a39cc70aa35cd849" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
data:image/s3,"s3://crabby-images/681ba/681ba7e1d19d2d281db9670e03a8159a5e86b487" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
好了,这就是一个简单的 PyQt 教程。
如果你还想要体验更多好玩儿的东西,你可以试着用一用别的组件。
data:image/s3,"s3://crabby-images/a50e5/a50e5aca49b5f364b54372f38d04551cc4c28e0b" alt="PyQt编写Python GUI程序,舍弃Tkinter,来玩易语言吧!"
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- python3基础之“术语表(2)” 2019-08-13
- python3 之 字符串编码小结(Unicode、utf-8、gbk、gb2312等 2019-08-13
- Python3安装impala 2019-08-13
- 小白如何入门 Python 爬虫? 2019-08-13
- python_字符串方法 2019-08-13
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash