官方文档
class QApplication
QApplication(arg__1)
Parameters
arg__1 – list of strings
QApplication专为QGuiApplication提供基于QWidget的应用程序所需的一些功能。 它处理小部件特定的初始化,完成。
对于任何使用Qt的GUI应用程序,无论该应用程序在任何给定时间有0、1、2或更多窗口,都只有一个QApplication对象。 对于基于非QWidget的Qt应用程序,请改用QGuiApplication,因为它不依赖于QtWidgets库。
一些GUI应用程序提供了特殊的批处理模式,即。 提供用于执行任务的命令行参数,而无需人工干预。 在这种非GUI模式下,实例化一个普通的QCoreApplication通常足以避免不必要地初始化图形用户界面所需的资源。 以下示例显示如何动态创建适当类型的应用程序实例:
# -*- coding: utf-8 -*-
"""
@File : test2.py
@Time : 2020/4/2 11:36
@Author : Dontla
@Email : sxana@qq.com
@Software: PyCharm
"""
import sys
from PyQt5.QtWidgets import QApplication
from PyQt5.QtCore import QCoreApplication
def main():
useGUI = not '-no-gui' in sys.argv
app = QApplication(sys.argv) if useGUI else QCoreApplication(sys.argv)
print(app)
return app.exec_()
if __name__ == '__main__':
main() # <PyQt5.QtWidgets.QApplication object at 0x000002859698D708>
app = QApplication(sys.argv)加入sys.argv这么一个参数有什么用?sys.argv是一组命令行参数的列表。Python可以在shell里运行,这个参数提供对脚本控制的功能。这句解释是官方教程中的,到底啥意思我现在也还不太懂。
Dontla:我也不太懂+1
可通过instance()函数访问QApplication对象,该函数返回与全局qApp指针等效的指针。
QApplication的主要职责是:
-
它将使用用户的桌面设置(例如:palette(),font()和doubleClickInterval())初始化应用程序。万一用户全局更改桌面(例如通过某种控制面板),它会跟踪这些属性。
-
它执行事件处理,这意味着它从底层窗口系统接收事件并将其分派到相关的小部件。通过使用sendEvent()和postEvent(),您可以将自己的事件发送到小部件。
-
它解析常见的命令行参数并相应地设置其内部状态。有关更多详细信息,请参见下面的构造函数文档。
-
它定义了应用程序的外观,并封装在QStyle对象中。可以在运行时使用setStyle()进行更改。
-
它提供了对本地可见的字符串的本地化功能,这些字符串可以通过translate()看到。
-
它提供了一些神奇的对象,例如desktop()和剪贴板()。
-
它知道应用程序的窗口。您可以使用widgetAt()询问哪个小部件在某个位置,获取topLevelWidgets()和closeAllWindows()的列表,等等。
-
它管理应用程序的鼠标光标处理,请参见setOverrideCursor()
由于QApplication对象进行了大量初始化,因此必须在创建与用户界面相关的任何其他对象之前创建它。 QApplication还处理常见的命令行参数。 因此,在应用程序本身对argv进行任何解释或修改之前,创建它通常是一个好主意。
功能组:
Groups | Functions |
---|---|
System settings | desktopSettingsAware() , setDesktopSettingsAware() , cursorFlashTime() , setCursorFlashTime() , doubleClickInterval() , setDoubleClickInterval() , setKeyboardInputInterval() , wheelScrollLines() , setWheelScrollLines() , palette() , setPalette() , font() , setFont() , fontMetrics() . |
Event handling | exec() , processEvents() , exit() , quit() . sendEvent() , postEvent() , sendPostedEvents() , removePostedEvents() , hasPendingEvents() , notify() . |
GUI Styles | style() , setStyle() . |
Text handling | installTranslator() , removeTranslator() translate() . |
Widgets | allWidgets() , topLevelWidgets() , desktop() , activePopupWidget() , activeModalWidget() , clipboard() , focusWidget() , activeWindow() , widgetAt() . |
Advanced cursor handling | overrideCursor() , setOverrideCursor() , restoreOverrideCursor() . |
Miscellaneous | closeAllWindows() , startingUp() , closingDown() . |
后面是介绍这个类的各种方法的,太多,不看了!!!
介绍
PyQt5是一个大的模块,是Qt在Python中的桥梁。
QtWidgets是PyQt5下面的一个模块,包含了用于构建界面的一系列UI元素组件。
QApplication是QtWidgets模块下面的一个类。
QtWidgets.QApplication基本用法
import sys
from PyQt5.QtWidgets import QApplication, QWidget
app = QApplication(sys.argv) # 实例化一个应用对象
w = QWidget() # 窗口界面的基本控件,它提供了基本的应用构造器。默认情况下,构造器是没有父级的,没有父级的构造器被称为窗口(window)。Dontla 20200402 啥意思,没看懂??
w.show() # 让控件在桌面上显示出来。控件在内存里创建,之后才能在显示器上显示出来。
sys.exit(app.exec_()) # 确保主循环安全退出
运行结果:
参考文章1:PyQT5.QtWidgets.QApplication结构及用法
参考文章2:Qt for Python 5.14.2 Qt for Python Documentation Qt Modules PySide2.QtWidgets QApplication