使用PyQt来编写第一个Python GUI程序

原文:使用PyQt来编写第一个Python GUI程序

本文由 伯乐在线 - Lane 翻译,Daetalus 校稿。未经许可,禁止转载!
英文出处:pythonforengineers.com。欢迎加入翻译小组

简介

许多人在学习如何创建一个 GUI 应用的时候都感到十分的困难。其中最重要的原因是,他们不知道应该从何下手。大多数的教程都只有文字,但事实上仅仅依靠文字很难学会 GUI 编程,因为 GUI 应用大多数都是基于视觉上的。

我们将通过创建一个简单的 GUI 应用来避免上面提到的这些问题,并且向你展示着手开始这件事其实是多么的简单。一旦你明白了这些基本的知识,以后的进一步学习将会变得十分的容易。

这就是我们即将完成的东西:

这是一个简单的 GUI 应用,根据输入的价格(price)和税率(tax rate),计算出最终的价格(final price)。

大多数的教程都试图直接通过代码来对 GUI 应用进行布局,但是这样做实在是很费劲。我们将要做的是利用优秀的 QT Designer 工具来对我们的应用进行布局。

所以不要再劳神费力的用代码来设计界面了。现在开始所有的东西都将通过图形界面来搞定。

所有的代码都在这里

前提条件

如果你已经接受了我的建议并且安装了 Anaconda,你应该已经安装好了 PyQt4。如果没有的话,你需要从这里先下载它。

同时你还需要一个 Qt Designer。我建议你下载整个的 QT 套件,因为其中还包含了许多其他有用的工具。

开始着手

提示:当你需要查看更多细节的时候,你可以通过点击下方的任意图片来查看其原图。(译者注:你可能需要查看原始链接来查看原图)

打开 QT Designer。在弹出的窗口中,选择 Main Window,这样它会给你一个空白的画板。

接下来在左侧选择Text Edit

Text Edit 拖动到主窗口:

看见右边我粗略的用红圈框起来的部分了吗?那就是定义这个对象的名字的地方。这个名字将是我们通过 Python 代码调用到这个对象的变量名,所以请尽量取一个有意义的名称。

我将它取名为price_box,因为我们会在这里输入价格。然后我们需要给这个输入框添加一个 label,以便让用户更加清楚这个输入框的作用。

我在上图中圈出了 label。把它拖动到主窗口当中来。

现在它被默认称作TextLabel。双击并将其命名为Price。你还可以将这段文字字体加大并且设置为粗体,就像下边看到的这样:

对于税率(tax)输入框,我们会使用另外的一个东西。找到spin box

左侧用圈框起来的部分就是一个spin box。它会限定你能输入的值。其实并不是非得要用spin box,这样做只不过是为了更好地展示 QT Creator 所能提供的各种不同的组件。将spin box 拖到窗口中。然后我们要做的第一件事情就是将objectName 改为一个有意义的名字,例如我将其设置为tax_rate。请记住这将会是你在 Python 代码中调用它的时候会使用到的变量名。

我们可以为我们的spin box 设置一个默认值。我选择将其设置为 20:

如果你仔细观察上图,你会发现我们也可以设置它的最小值和最大值。不过我并不打算去更改他们。

同样地,我会为它添加一个标签叫做Tax Rate。然后看看我们接下来会用到的圈起来的Push Button

好的,现在选择Push Button 然后将其拖动到我们的窗口中来。

这个按钮现在显示的是PushButton,这并不是一个很有意义的名字。到了这一步,你应该知道该怎么更改它了。不过在此之前,我们要把这个按钮的名字(不是显示用的文字列)改为calc_tax_button

然后,我们可以修改真正的显示文字列了:

然后选择另外一个Text Edit 并将其拖动到窗口中。你不需要给它添加标签,因为我们会把我们的结果输出到这里。把它的名字改为results_window(下图中没有画出来,但你应该已经知道该如何操作了)。

如果你觉得需要的话,你可以添加一个大标题。这是一个简单的label box 并且将字体加大了。

现在保存你的成果:

这个文件在下一部分我们编写代码的时候将会用到,所以最好把它存在一个我们方便访问的地方。

我们创建的只是一个简单的 XML 文件。用任意一个文本编辑器打开它,你可以看到这样的内容:

编写代码

Qt 代码是面向对象的,并且简单易学。所有我们添加的组件都是一个对象,并且都拥有自己的方法比如toPlainText()(用来读取输入框中的值)。这让它使用起来非常方便。

在你编写代码之前,你必须要使用一些函数来进行配置。我确信官方的文档中肯定有提到过这个,但是我现在打死也找不到这些文档了,所以我只能通过官方的例程(以及网上的一些教程)中总结出了这一小段代码来进行配置。我已经把这些函数上传到了 pyqt_skeleton.py

这些代码非常有用,每当你想要创建一个新的 PyQt 项目的时候,就在这段代码的基础上添加你自己的代码吧。

这段代码如下:


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

import sys

from PyQt4 import QtCore, QtGui, uic

 

qtCreatorFile = "" # Enter file here.

 

Ui_MainWindow, QtBaseClass = uic.loadUiType(qtCreatorFile)

 

class MyApp(QtGui.QMainWindow, Ui_MainWindow):

    def __init__(self):

        QtGui.QMainWindow.__init__(self)

        Ui_MainWindow.__init__(self)

        self.setupUi(self)

 

if __name__ == "__main__":

    app = QtGui.QApplication(sys.argv)

    window = MyApp()

    window.show()

    sys.exit(app.exec_())

其中需要注意的是第三行:


1

qtCreatorFile = "" # Enter file here.

你需要在这里填入你先前创建的文件的地址。这个文件将会被内置的函数载入:


1

Ui_MainWindow, QtBaseClass = uic.loadUiType(qtCreatorFile)

让我们大致地看一看这段代码:


1

2

3

4

5

if __name__ == "__main__":

    app = QtGui.QApplication(sys.argv)

    window = MyApp()

    window.show()

    sys.exit(app.exec_())

这段主程序创建了一个新的 Qt Gui 应用。,每个 QT 应用都可以通过命令行进行配置,所以必须传入sys.argv 参数。不过现在我们用不到这个。最后,我们创建了一个MyApp 类,这个类继承于 Qt 库并且调用了父类的初始化函数:


1

2

3

4

5

class MyApp(QtGui.QMainWindow, Ui_MainWindow):

    def __init__(self):

        QtGui.QMainWindow.__init__(self)

        Ui_MainWindow.__init__(self)

        self.setupUi(self)

你不一定非得要了解这些代码的细节。你只需要在它的基础上继续开发就好了。

下载pyqt_skeleton.py 这个文件,并将它重命名为pyqt_first.py。这是因为我们不想去改动到源文件。然后要做的第一件事就是在代码中导入我们自己的 XML 文件,这个 XML 文件包含了我们的这个 GUI 信息。将下面的这一行:


1

qtCreatorFile = "" # Enter file here.

替换为


1

qtCreatorFile =  "tax_calc.ui"

这样就能把我们的 GUI 文件载入到内存中。现在,我们的 GUI 中最关键的组件就是我们的这个按钮了。一旦我们按下这个按钮,就会发生一些神奇的事情。到底会发生什么?这就需要我们告诉代码当按下Calculate Tax 按钮的时候该怎么做了。在__init__ 函数中,添加如下的内容:


1

self.calc_tax_button.clicked.connect(self.CalculateTax)

这段代码有什么用?还记得我们把按钮命名为了calc_tax_button 吗?(这是这个按钮对象的名字,不是按钮上显示的提示字符串。)clicked 是一个内置的函数,当有按钮被点击的时候它会被自动调用(很神奇吧)。所有的 QT 组件都有特定的函数,你可以通过 Google 来查看详细。这段代码的最后部分是connect(self.CalculateTax)。这意味着这个按钮会被链接到一个叫做self.CalculateTax 的函数,这样以后每当用户按下这个按钮的时候,这段代码都会被调用。

我们还没有实现这个函数。所以让我们动手开始写吧。

MyApp 类中,添加另外一个函数。我们需要先看看整个函数,然后再去了解它的细节:


1

2

3

4

5

6

def CalculateTax(self):

        price = int(self.price_box.toPlainText())

        tax = (self.tax_rate.value())

        total_price = price  + ((tax / 100) * price)

        total_price_string = "The total price with tax is: " + str(total_price)

        self.results_window.setText(total_price_string)

好了,让我们一行一行的分析上面的代码。

我们现在要做两件事:读取价格和税率,然后计算最终的价格。好了开始吧。请记住,我们要通过我们设定的名字来调用这些组件(这就是我让你不要用默认的通用名称比如box1 的原因,否则的话我们在写代码的时候会很恼火)。


1

price = int(self.price_box.toPlainText())

price_box.toPlainText() 是一个内置的可以读取输入框中的值的函数。顺便提一句,虽然你用得多了以后肯定能记住这些函数,因为他们的名字取得很规范,但是你没必要一开始就去记忆所有这些函数。我每次都是通过 Google 诸如 “Qt Textbox 读取数据”一类的关键字来找到我所需要的函数。

通过函数读取到的是一个 string 类型的值,所以我们需要把他转换成 integer 类型并存在一个price变量中。

然后读取税率:


1

tax = (self.tax_rate.value())

同样的,value() 是读取spinbox 中值的函数。感谢 Google。

我们现在已经得到了以上两个值,这样我们就能用非常高大上的数学公式来计算我们的最终价格了:


1

2

total_price = price  + ((tax / 100) * price)

total_price_string = "The total price with tax is: " + str(total_price)

我们新建了一个 string 变量来储存我们的最终价格。因为最终直接显示在应用上的将会是一个 string 类型的值:


1

self.results_window.setText(total_price_string)

results_window 中,我们调用了setText() 函数,它能显示我们计算出的最终价格的字符串。

最后运行我们写好的程序:


1

python pyqt_first.py

好了,这就是一个简单的 PyQt 教程。

如果你还想要体验更多好玩儿的东西,你可以试着用一用别的组件,不过先提醒一句,你要是放了太多的组件在你的应用中的话,用起来可能会有点费劲…

关于作者: Lane

时间: 2025-01-21 01:16:38

使用PyQt来编写第一个Python GUI程序的相关文章

使用NetBeans IDE设计一个Swing GUI程序

教程中您将会学到如何: 使用GUI Builder 界面 创建一个 GUI 容器 添加组件 调整组件大小 对齐组件 调整组件锚距 设置组件自动调整大小行为 编辑组件属性 本教程大约需要30分钟的时间完成. 注意:当您看到 图示,表示您可以通过点击它查看更为详细的GUI Builder相关功能的交互式解说. 入门 IDE的GUI Builder能让那些没有深入了解布局管理的用户创建一个具有专业级外观的GUI应用变为可能. 有关GUI Builder的可视化反馈描述,您可以查阅 GUI Builde

Android开发之编写第一个Android应用程序实现按钮和复选框

搞Android系统这么久了,说实话,我连apk怎么写还真是不会,说实话能够看懂,简单改改就不错了,说来惭愧,我是嵌入式出身.最近开始学习Android应用开发,和我的底层结合起来,为了工作,咬着牙也要学下去!!! 首先,我使用的是Android Studio这个软件. 上谷歌中国网就可以下载到了,地址如下: https://developer.android.google.cn/develop/index.html     编译环境配置,找百度看看就行了,这里不哆嗦.     安装好后,有一些

Python 爬虫程序 PySpider

问题描述 PySipder 是一个 Python 爬虫程序演示地址:**://demo.pyspider.org/使用 Python 编写脚本,提供强大的 APIPython 2&3强大的 WebUI 和脚本编辑器.任务监控和项目**和结果查看支持 JavaScript 页面后端系统支持:MySQL, MongoDB, SQLite, Postgresql支持任务优先级.重试.定期抓取等分布式架构示例代码:from pyspider.libs.base_handler import * cl**

《21天学通C语言(第6版•修订版)》一1.5 第一个C语言程序

1.5 第一个C语言程序 21天学通C语言(第6版•修订版)读者也许迫不及待地想编写第一个C语言程序.为帮助读者熟悉编译器,程序清单1.1包含一个小型程序,功能快速地完成.现在,读者也许无法理解其中的所有内容,但不用担心,尽管编写.编译并运行它. 这里的演示使用的是一个名为hello.c的程序,该程序只是将单词"Hello, World!"显示到屏幕上而已.该程序常被用来介绍C语言编程,很适合读者进行学习.程序清单1.1列出了hello.c的源代码.输入该程序清单时,请不要输入最左边的

《Python语言程序设计》——2.2 编写一个简单的程序

2.2 编写一个简单的程序 关键点:编写一个涉及设计解决问题的策略的程序,然后使用程序设计语言实现这些策略.首先,让我们来看一个计算圆面积的简单问题.我们该如何编写程序来解决这个问题呢?编写程序涉及如何设计算法以及如何将算法翻译成程序设计指令或代码.当你编写代码时--即你在编写程序时--你就将一个算法翻译成一段程序.算法描述的是如何通过列出要进行的动作和这些动作的执行顺序来解决一个问题.算法可以帮助程序员在使用程序设计语言编程之前做一个规划.算法可以用自然语言或伪代码(即自然语言与某些程序设计代

PyQt4 Python GUI窗体应用程序

前言 还是一句老话,公司要什么我就做什么.这次来玩Python的GUI编程,做一个用于监控警报.简化SOP的窗体应用程序.首先当然是部署开发环境了,这次用PyCharm5+Python3.4+PyQt4(QT Designer) 软件环境 系统  Win10 软件  Python 3.4.3 PyCharm 5.0.4 PyQt 4 IPython 4.0.0 Powershell 3.0 PyQT简介 PyQt是一个创建GUI应用程序的工具包.它是Python编程语言和Qt库的成功融合.Qt库

Windows中使用wxPython和py2exe开发Python的GUI程序的实例教程_python

Python是支持可视化编程,即编写gui程序,你可以用它来编写自己喜欢的桌面程序.使用wxPython来做界面非常的简单,只是不能像C#一样拖动控件,需要自行写代码布局.在完成编写之后,由于直接的py文件不能再没有安装python的电脑上运行,能否有一个打包成在任意电脑都能运行的工具,网上找找发现了py2exe正好可以完成这个功能.wxPython和py2exe都是开源免费软件. 环境配置wxPython: sourceforge项目页https://sourceforge.net/proje

PyQt 4.8.5发布 创建GUI应用程序的工具包

PyQt 4.8.5这是一个小的错误修正版. PyQt是一个创建GUI应用程序的工具包.它是Python编程语言和Qt库的成功融合.Qt库是这个星球上最强大的库之一,在更强大库出现之前.PyQt是由http://www.aliyun.com/zixun/aggregation/29869.html">Phil Thompson 开发. PyQt实现了一个Python模块集.它有超过300类,将近6000个函数和方法.它是一个多平台的工具包,可以运行在所有主要操作系统上,包括UNIX,Win

PyQt v4.8.3发布 创建GUI应用程序的工具包

PyQt是一个创建GUI应用程序的工具包.它是Python编程语言和Qt库的成功融合.Qt库是这个星球上最强大的库之一,在更强大库出现之前.PyQt是由http://www.aliyun.com/zixun/aggregation/29869.html">Phil Thompson 开发. PyQt实现了一个Python模块集.它有超过300类,将近6000个函数和方法.它是一个多平台的工具包,可以运行在所有主要操作系统上,包括UNIX,Windows和Mac. PyQt采用双许可证,开发