You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
qasync allows coroutines to be used in PyQt/PySide applications by providing an implementation of the PEP 3156 event loop.
With qasync, you can use asyncio functionalities directly inside Qt app's event loop, in the main thread. Using async functions for Python tasks can be much easier and cleaner than using threading.Thread or QThread.
If you need some CPU-intensive tasks to be executed in parallel, qasync also got that covered, providing QEventLoop.run_in_executor which is functionally identical to that of asyncio. By default QThreadExecutor is used, but any class implementing the concurrent.futures.Executor interface will do the job.
Basic Example
importasyncioimportsysfromPySide6.QtWidgetsimportQVBoxLayout, QWidgetfromqasyncimportQApplication, QEventLoopclassMainWindow(QWidget):
def__init__(self):
super().__init__()
self.setLayout(QVBoxLayout())
self.lbl_status=QLabel("Idle", self)
self.layout().addWidget(self.lbl_status)
@asyncCloseasyncdefcloseEvent(self, event):
pass@asyncSlot()asyncdefonMyEvent(self):
passif__name__=="__main__":
app=QApplication(sys.argv)
app_close_event=asyncio.Event()
app.aboutToQuit.connect(app_close_event.set)
main_window=MainWindow()
main_window.show()
# for 3.11 or older use qasync.run instead of asyncio.run# qasync.run(app_close_event.wait())asyncio.run(app_close_event.wait(), loop_factory=QEventLoop)
qasync is a fork of asyncqt, which is a fork of quamash. qasync was created because those are no longer maintained. May it live longer than its predecessors.
qasync will continue to be maintained, and will still be accepting pull requests.
Requirements
Python >=3.8, <3.14
PyQt5/PyQt6 or PySide2/PySide6
qasync is tested on Ubuntu, Windows and MacOS.
If you need Python 3.6 or 3.7 support, use the v0.25.0 tag/release.
Installation
To install qasync, use pip:
pip install qasync
License
You may use, modify and redistribute this software under the terms of the BSD License. See LICENSE.
About
Python library for using asyncio in Qt-based applications.