使用 Python 构建用户界面 - PyQt 和 Tkinter 比较
您是否厌倦了您创建的所有在控制台中运行的程序?尝试图形界面!这在 Python 中很容易做到。
PyQt 还是 Tkinter?
PyQt 和 Tkinter 是您可以使用 Python 构建用户界面的两个主要库。具体使用哪一个,取决于你想要实现的目标,选择一个更适合项目的。
Tkinter:
- 简单轻便。这使您可以快速轻松地设置图形应用程序。
- 功能略逊色于 PyQt 。
- GUI 很难定制。
- 使用事件来管理交互。
PyQt:
- 复杂!掌握起来比Tkinter略有难度一些,但一旦掌握了 PyQt,就可以构建一切。
- 使用样式表 (CSS) 可以轻松定制 GUI。
- 使用信号槽系统,这对初学者来说可能有点混乱。
了解这两个库的优缺点,最终让我们知道如何使用它们,并根据项目决定使用哪一个。Tkinter 对于需要快速设置的小型项目很有用。当项目较大时,PyQt 则更胜一筹。
就个人而言,如果你必须学习两者之一,我会推荐 PyQt。学习和掌握它需要更长的时间,但是当你掌握好它时,可能性是无穷无尽的。
PyQt
今天,我将只谈论 PyQt。想了解如何使用Tkinter,可以阅读《使用 Tkinter 创建桌面应用程序》。
安装
您可以安装PyQt5或PyQt6。他们几乎是一样的。PyQt6 是 PyQt5 的升级版,但并没有改变很多东西。
pip install PyQt5
# 或者
pip install PyQt6
第一个窗口
让我们首先导入一些小部件,因为我们需要它们来创建我们的窗口(我们将在下一节中看到什么是小部件)。
from PyQt5.QtWidgets import QApplication, QLabel
QApplication 是 PyQt 应用程序的包装器。 它是每个 Qt 程序的基本元素。 让我们创建我们的应用程序:
import sys
app = QApplication(sys.argv)
sys.argv 是在执行脚本时传递的参数。您应该知道必须传递参数来实例化 QApplication,至少传递一个空列表作为参数。
现在我们将稍微装饰一下我们的应用程序:
label = QLabel("Hello")
label.show()
QLabel 是显示一些文本的 Qt 小部件, 我们创建它,然后调用 show 方法来显示它。
然后,我们必须执行我们的应用程序:
app.exec_()
创建一个简单窗口的完整代码是:
import sys
from PyQt5.QtWidgets import QApplication, QLabel
app = QApplication(sys.argv)
label = QLabel("Hello")
label.show()
app.exec_()
小部件
小部件是您在 PyQt 应用程序中看到的一切。如果你放置文本,它就是一个小部件,按钮是小部件,滑块是小部件,等等......甚至你的窗口也是一个小部件。
小部件可以相互嵌套。例如,我的窗口是一个包含其他小部件(如按钮)的小部件,这些小部件又包含像文本这样的小部件。
它们有很多,如果您制作 Qt 应用程序,您肯定会用到很多。我们将看到QLabel和QPushButton。想了解更多小部件可以查看 PyQt5 文档(
https://doc.qt.io/qtforpython-5/)
QLabel
它只是一个包含文本的小部件。我们在构建它时传递要显示的文本。
label = QLabel("Hello")
QPushButton
它是一个代表按钮的小部件。与 QLabel 相同的方式,我们将按钮的文本传递给它。
button = QPushButton("I'm a button!")
单击按钮时如何分配操作?
稍后我们将在研究信号和槽时看到:)
布局
布局也是小部件。但是,它们有点特殊,因为它们没有图形外观。它们只是告诉您如何在窗口中排列小部件。
让我们开始创建我们的第一个布局,一个 QVBoxLayout。 这是一个允许我们将小部件堆叠在一起的布局。
from PyQt5.QtWidgets import QVBoxLayout
vbox = QVBoxLayout()
现在我们已经创建了一个布局,我们需要用小部件填充它。
button1 = QPushButton("Button 1")
button2 = QPushButton("Button 2")
vbox.addWidget(button1)
vbox.addWidget(button2)
现在添加了两个垂直显示的按钮。接下来我们该怎么办?
我们首先创建一个应用程序,在其中创建一个窗口,然后将我们的布局添加到其中。最后,我们显示我们的窗口,完整代码如下:
from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QPushButton
app = QApplication([])
window = QWidget()
vbox = QVBoxLayout()
button1 = QPushButton("Button 1")
button2 = QPushButton("Button 2")
vbox.addWidget(button1)
vbox.addWidget(button2)
window.setLayout(vbox)
window.show()
app.exec()
运行这段代码,您会看到一个漂亮的窗口,其中包含两个按钮。
设计您的应用程序
如果你想为你的应用设计样式,你可以通过以下几种方式来实现:
- 基本样式。
- 调色板。
- 样式表。
基本样式
PyQt 提供了几种基本样式,可以轻松切换。它们完全改变了您的应用程序的外观。这里是其中的一些:
- Fusion
- Windows
- WindowsVista
- Macintosh
- …...
要应用样式,我们使用应用程序的 setStyle 方法:
app.setStyle("Windows")
调色板
也许您只想更改颜色而不是重新设计整个样式。为此,我们使用 QPalette。它允许您进行颜色映射。例如:
from PyQt5.QtCore import Qt
from PyQt5.QtGui import QPalette
palette = QPalette()
palette.setColor(QPalette.ButtonText, Qt.green)
app.setPalette(palette)
在此示例中,我们更改了应用程序中每个按钮文本的颜色并将其设置为绿色。
更详细的QPalette使用可以查看文档(
https://doc.qt.io/qtforpython-5/PySide2/QtGui/QPalette.html)
样式表
最后,修改 PyQt 应用程序设计的最完整方法是使用样式表。为此,只需将样式表存储在字符串中,然后像这样修改样式:
stylesheet = "QPushButton { margin-bottom: 5ex; }"
app.setStyleSheet(stylesheet)
因此,您可以创建一个 .css 文件,用样式填充它,然后提取其内容并将其用作 PyQt 样式表。
信号与槽
这些概念可能是 PyQt 中最难理解的。执行动作时会发送信号,槽是响应该信号而执行的动作。例如,当一个按钮被点击时,它会发送一个信号说按钮被点击了,并且可以将它连接到一个插槽以显示响应该点击的文本,或者开始下载等......
PyQt 的小部件提供了许多信号。例如,上面提到的信号可以通过这种方式检索:
button = QPushButton("Hello")
button.clicked.connect(...)
所以,我们有这样的语法:widget.signal.connect(function).
如果我想在单击按钮时显示控制台文本,我会这样做:
def hello():
print("hello")
button.clicked.connect(hello)
你总是必须连接一个函数。所以如果我尝试这样做:
button.clicked.connect(hello())
我会得到一个错误,因为 hello() 不是函数,而是 hello 返回的值。 所以这就是 lambda 函数派上用场的地方,这样你就可以避免编写太多的基本函数。
button.clicked.connect(lambda x: print("hello"))
您可以在 PyQt 文档中找到有关每个小部件的信号的更多信息!
最后
关于 PyQt 有很多内容,一篇短文很难把全部内容讲完。这个库可能很难理解,但是一旦你掌握了窍门,一切都会变得容易。