PyQt
PyQt is a Python binding of the cross-platform GUI toolkit Qt, implemented as a Python plug-in. PyQt is free software developed by the British firm Riverbank Computing. It is available under similar terms to Qt versions older than 4.5; this means a variety of licenses including GNU General Public License (GPL) and commercial license, but not the GNU Lesser General Public License (LGPL).[3] PyQt supports Microsoft Windows as well as various kinds of UNIX, including Linux and MacOS (or Darwin).[4]
Developer(s) | Riverbank Computing |
---|---|
Initial release | 1998 |
Stable release | 6.5.2[1]
/ 24 July 2023 |
Written in | C++ / Python[2] |
Operating system | Cross-platform |
License | GNU GPL and commercial |
Website | riverbankcomputing.com |
PyQt implements around 440 classes and over 6,000 functions and methods[5] including:
- a substantial set of GUI widgets
- classes for accessing SQL databases (ODBC, MySQL, PostgreSQL, Oracle, SQLite)[6]
- QScintilla, Scintilla-based rich text editor widget
- data aware widgets that are automatically populated from a database
- an XML parser
- SVG support
- classes for embedding ActiveX controls on Windows (only in commercial version)[7]
To automatically generate these bindings, Phil Thompson developed the tool SIP, which is also used in other projects.
History
PyQt was first released by Riverbank Computing in 1998.[8]
In August 2009, Nokia sought for the Python binding to be available under the LGPL license. At the time, Nokia owned Qt Software, the developer of QT. After failing to reach an agreement with Riverbank Computing, Nokia released its binding, PySide, providing similar functionality.[9]
Main components
PyQt4 contains the following Python modules.
- The QtCore module contains the core non-GUI classes, including the event loop and Qt's signal and slot mechanism. It also includes platform independent abstractions for Unicode, threads, mapped files, shared memory, regular expressions, and user and application settings.
- The QtGui module contains the majority of the GUI classes. These include a number of table, tree and list classes based on the model–view–controller design pattern. Also provided is a sophisticated 2D canvas widget capable of storing thousands of items including ordinary widgets.
- The QtNetwork module contains classes for writing UDP and TCP clients and servers. It includes classes that implement FTP and HTTP clients and support DNS lookups. Network events are integrated with the event loop making it very easy to develop networked applications.
- The QtOpenGL module contains classes that enable the use of OpenGL in rendering 3D graphics in PyQt applications.
- The QtSql module contains classes that integrate with open-source and proprietary SQL databases. It includes editable data models for database tables that can be used with GUI classes. It also includes an implementation of SQLite.
- The QtSvg module contains classes for displaying the contents of SVG files. It supports the static features of SVG 1.2 Tiny.
- The QtXml module implements SAX and DOM interfaces to Qt's XML parser.
- The QtMultimedia module implements low-level multimedia functionality. Application developers would normally use the phonon module.
- The QtDesigner module contains classes that allow Qt Designer to be extended using PyQt.
- The Qt module consolidates the classes contained in all of the modules described above into a single module. This has the advantage that you don't have to worry about which underlying module contains a particular class. It has the disadvantage that it loads the whole of the Qt framework, thereby increasing the memory footprint of an application. Whether you use this consolidated module, or the individual component modules is down to personal taste.
- The uic module implements support for handling the XML files created by Qt Designer that describe the whole or part of a graphical user interface. It includes classes that load an XML file and render it directly, and classes that generate Python code from an XML file for later execution.[10]
PyQt5 contains the following Python modules:
- QtQml Module
- QtQtuick Module
- QtCore Module
- QtGui Module
- QtPrintSupport Module
- QtWidgets Module
- QGLContext Module
- QGLFormat Module
- QGLWidget Module
- QtWebKit Module
- QtWebKitWidgets Module
Versions
PyQt version 4 works with both Qt 4 and Qt 5. PyQt version 5 only supports Qt version 5,[4] and drops support for features that are deprecated in Qt 5.[11]
Hello World example
The below code shows a small window on the screen.
PyQt4
#! /usr/bin/env python3
# Character Encoding: UTF-8
#
# Here we provide the necessary imports.
# The basic GUI widgets are located in the QtGui module.
import sys
from PyQt4.QtGui import QApplication, QWidget
# Every PyQt4 application must create an application object.
# The application object is located in the QtGui module.
app = QApplication(sys.argv)
# The QWidget widget is the base class of all user interface objects in PyQt4.
# We provide the default constructor for QWidget. The default constructor has no parent.
# A widget with no parent is called a window.
root = QWidget()
root.resize(320, 240) # The resize() method resizes the widget.
root.setWindowTitle("Hello, World!") # Here we set the title for our window.
root.show() # The show() method displays the widget on the screen.
sys.exit(app.exec_()) # Finally, we enter the mainloop of the application.
PyQt5
#! /usr/bin/env python3
# Character Encoding: UTF-8
#
# Here we provide the necessary imports.
# The basic GUI widgets are located in the QtWidgets module.
import sys
from PyQt5.QtWidgets import QApplication, QWidget
# Every PyQt5 application must create an application object.
# The application object is located in the QtWidgets module.
app = QApplication([])
# The QWidget widget is the base class of all user interface objects in PyQt5.
# We provide the default constructor for QWidget. The default constructor has no parent.
# A widget with no parent is called a window.
root = QWidget()
root.resize(320, 240) # The resize() method resizes the widget.
root.setWindowTitle("Hello, World!") # Here we set the title for our window.
root.show() # The show() method displays the widget on the screen.
sys.exit(app.exec_()) # Finally, we enter the mainloop of the application.
PyQt6
#! /usr/bin/env python3
# Character Encoding: UTF-8
#
# Here we provide the necessary imports.
# The basic GUI widgets are located in QtWidgets module.
import sys
from PyQt6.QtWidgets import QApplication, QWidget
# Every PyQt6 application must create an application object.
# The application object is located in the QtWidgets module.
app = QApplication([])
# The QWidget widget is the base class of all user interface objects in PyQt6.
# We provide the default constructor for QWidget. The default constructor has no parent.
# A widget with no parent is called a window.
root = QWidget()
root.resize(320, 240) # The resize() method resizes the widget.
root.setWindowTitle("Hello, World!") # Here we set the title for our window.
root.show() # The show() method displays the widget on the screen.
sys.exit(app.exec()) # Finally, we enter the mainloop of the application.
Notable applications that use PyQt
- Anki, a spaced repetition flashcard program
- Calibre, an E-book management application
- Dropbox, a file hosting service
- Eric Python IDE
- Frescobaldi, a score editor for LilyPond music files
- Kodos, a Python Regular expression Debugger
- Leo, an outliner and literate programming editor
- Ninja-IDE, an extensible open-source Python IDE
- OpenLP, an open-source lyrics projection program
- OpenShot, a video editing program
- Orange, a data mining and visualization framework
- Puddletag, an open-source, cross-platform ID3 tag editor
- QGIS, a free software desktop Geographic Information Systems (GIS) application
- qutebrowser, a web browser with Vim-style key bindings and a minimal GUI.
- qt-recordMyDesktop, a Qt4 frontend for recordMyDesktop
- Spyder, a Python data science IDE
- TortoiseHg, a graphical interface for the Mercurial source management program (Hg)
- Veusz, a scientific plotting application
- GNS3, a network software emulator
See also
References
- Error: Unable to display the reference properly. See the documentation for details.
- "PyQt4 Download". Riverbankcomputing. 2010. Retrieved 2010-04-19.
- "Riverbank | Commercial | License FAQ". Riverbankcomputing.com. Retrieved 2015-06-24.
- "What is PyQt?". Riverbank Computing. Retrieved 2014-09-18.
- "PyQt v4 - Python Bindings for Qt v4". Riverbankcomputing. Archived from the original on 2008-04-29. Retrieved 2010-04-17.
- "QSqlDatabase Class Reference". Pyqt.sourceforge.net. Retrieved 2014-09-25.
- PythonInfo Wiki
- Jarmul, Katharine; Lawson, Richard (2017-05-30). Python Web Scraping. Packt Publishing Ltd. p. 105. ISBN 978-1-78646-429-3.
- faq, Martin Fitzpatrick Last updated (2019-06-21). "PyQt5 vs PySide2: What's the difference between the two Python Qt libraries?". Python GUIs. Retrieved 2022-06-25.
- "Riverbank | Software | PyQt | What is PyQt?". Riverbankcomputing.co.uk. Retrieved 2010-04-15.
- "Differences Between PyQt4 and PyQt5", PyQt 5.3.2 Reference Guide, archived from the original on 2018-08-14, retrieved 2014-09-18
Further reading
- Willman, Joshua (2020), Beginning PyQt - A Hands-on Approach to GUI Programming (1st ed.), Apress, p. 440, ISBN 978-1-4842-5856-9
- Summerfield, Mark (October 28, 2007), Rapid GUI Programming with Python and Qt (Covers PyQt4) (1st ed.), Prentice Hall, p. 648, ISBN 978-0-13-235418-9
- Rempt, Boudewijn (2002), GUI Programming with Python: QT Edition (Covers PyQt3), OpenDocs, archived from the original on 2010-04-09