Source code for qt_multithreading_wrapper

import traceback, sys
from PyQt5.QtCore import QRunnable, QObject, pyqtSignal


[docs]class WorkerSignals(QObject): """ Defines the signals available from a running worker thread. Supported signals are: Attributes: finished (pyqtSignal): No data error (pyqtSignal): `tuple` (exctype, value, traceback.format_exc() ) result (pyqtSignal): `object` data returned from processing, anything """ finished = pyqtSignal() started = pyqtSignal() error = pyqtSignal(tuple) result = pyqtSignal(object)
[docs]class Worker(QRunnable): """ Worker thread Inherits from QRunnable to handler worker thread setup, signals and wrap-up. :param callback: The function callback to run on this worker thread. Supplied args and kwargs will be passed through to the runner. :type callback: function :param args: Arguments to pass to the callback function :param kwargs: Keywords to pass to the callback function """ def __init__(self, fn, *args, **kwargs): super(Worker, self).__init__() # Store constructor arguments (re-used for processing) self.fn = fn self.args = args self.kwargs = kwargs self.signals = WorkerSignals() # @pyqtSlot()
[docs] def run(self): """ Initialise the runner function with passed args, kwargs. """ # Retrieve args/kwargs here; and fire processing using them self.signals.started.emit() try: result = self.fn(*self.args, **self.kwargs) except: traceback.print_exc() exctype, value = sys.exc_info()[:2] self.signals.error.emit((exctype, value, traceback.format_exc())) else: self.signals.result.emit(result) # Return the result of the processing finally: self.signals.finished.emit() # Done