Python. Отправка сигнала от воркера

Я работаю в приложении Python, используя PySide на Raspberry Pi, с ОС Raspbian Jessie.

Я новичок в Python и совсем не эксперт. Так что, наверное, это вопрос начинающего.

В моем приложении у меня есть:

  • основной поток -> Gui Thread, который реализует интерфейс.
  • подчиненный поток -> Выполняет некоторую долгую работу (вообще без графического интерфейса, простой код), реализован в пользовательском классе MyWorker.

В некоторых местах кода нижележащего потока мне нужно испустить сигнал, который должен быть уловлен основным потоком. В предыдущей версии я делал так:

Код основного потока

    #Slot for clicked button
    def Slot_Start_Calculation (self):

        self.MyLongThread = QThread()
        MyLongWorker = MyWorker(self, Qty)
        MyLongWorker.moveToThread(self.MyLongThread)

        self.MyLongThread.started.connect(MyLongWorker.Run_LongWorker)
        MyLongWorker.WorkerFinished.connect(self.MyLongThread.quit)
        MyLongWorker.WorkerFinished.connect(self.MyLongWorker.deleteLater)
        MyLongThread.finished.connect(self.MyLongThread.deleteLater)

        MyLongThread.start()


    def Slot_Worker_Sent_A_Signal (self, Result):

        print ("Worker sent this result: " + str(Result))
        .
        .
        .

Код MyWorker

class MyWorker(QObject):

    WorkerFinished = Signal()
    CustomSignal = Signal(int)

    def __init__(self, parent, Quantity)

        super().__init__(parent)
        self_parent = parent
        self.Quantity = Quantity
        print("Myworker's constructor")

    def __del__(self):
        print("Myworker's destructor")


    def Run_LongWorker (self):

        self.CustomSignal.connect(self.parent.Slot_Worker_Sent_A_Signal)
        .
        .
        .
        self.CustomSignal.emit(MyPartialResult)
        .
        .
        .
        self.WorkerFinished.emit()

Этот код запущен в тестовой среде несколько недель назад, пока я заканчиваю некоторые детали графического интерфейса, и я не заметил ничего плохого. Вчера, ища в сети, я случайно заметил, что QObject :: moveToThread не может перемещать объекты с родителем.

https: [// forum.qt.io/topic/40653/qobject-movetothread-cannot-move-objects-with-a-parent sizes[1]

поэтому я боюсь, что в моем коде могут быть проблемы, которые я еще не обнаружил.

Я изменил эту часть кода, и теперь она:

Новый код для основного потока

    #New slot for clicked button.
    def Slot_Start_Calculation (self):

        MyLongThread = QThread()
        MyLongWorker = MyWorker(Qty)
        MyLongWorker.moveToThread(MyLongThread)

        MyLongThread.started.connect(MyLongWorker.Run_LongWorker)
        MyLongWorker.WorkerFinished.connect(MyLongThread.quit)
        MyLongWorker.WorkerFinished.connect(MyLongWorker.deleteLater)
        MyLongThread.finished.connect(MyLongThread.deleteLater)

        MyLongThread.start()


    def Slot_Worker_Sent_A_Signal (self, Result):

        print ("Worker sent this result: " + str(Result))
        .
        .
        .

Новый код для MyWorker

class MyWorker(QObject):

    WorkerFinished = Signal()
    CustomSignal = Signal(int)

    def __init__(self, Quantity)

        super().__init__()
        self.Quantity = Quantity
        print("Myworker's constructor")

    def __del__(self):
        print("Myworker's destructor")

    def Run_LongWorker (self):

        self.CustomSignal.connect( ??? .Slot_Worker_Sends_A_Signal)
        .
        .
        .
        self.CustomSignal.emit(MyPartialResult)
        .
        .
        .
        self.WorkerFinished.emit()

Итак, теперь я действительно не знаю, как подключить этот сигнал к слоту, который находится в основном потоке, потому что, если я не ошибаюсь, нет отношения родитель / потомок, так как я изменил сходство потока.

Может ли кто-нибудь сказать мне, есть ли способ сделать это, и направить меня к документации по этой проблеме?

Спасибо заранее.

Почему в Python есть оператор "pass"?
Почему в Python есть оператор "pass"?
Оператор pass в Python - это простая концепция, которую могут быстро освоить даже новички без опыта программирования.
Некоторые методы, о которых вы не знали, что они существуют в Python
Некоторые методы, о которых вы не знали, что они существуют в Python
Python - самый известный и самый простой в изучении язык в наши дни. Имея широкий спектр применения в области машинного обучения, Data Science,...
Основы Python Часть I
Основы Python Часть I
Вы когда-нибудь задумывались, почему в программах на Python вы видите приведенный ниже код?
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
LeetCode - 1579. Удаление максимального числа ребер для сохранения полной проходимости графа
Алиса и Боб имеют неориентированный граф из n узлов и трех типов ребер:
Оптимизация кода с помощью тернарного оператора Python
Оптимизация кода с помощью тернарного оператора Python
И последнее, что мы хотели бы показать вам, прежде чем двигаться дальше, это
Советы по эффективной веб-разработке с помощью Python
Советы по эффективной веб-разработке с помощью Python
Как веб-разработчик, Python может стать мощным инструментом для создания эффективных и масштабируемых веб-приложений.
1
0
58
1

Ответы 1

Наконец, думаю, я нашел ответ. В конструкторе класса Worker мне пришлось изменить ссылку на родительский объект и вызов init суперкласса.

class MyWorker(QObject):

    WorkerFinished = Signal()
    CustomSignal = Signal(int)

    def __init__(self, parent = None, Quantity)
        super().__init__()
        self.Quantity = Quantity
        print("Myworker's constructor")

    def __del__(self):
        print("Myworker's destructor")


    def Run_LongWorker (self):

        .
        .
        .
        self.CustomSignal.emit(MyPartialResult)
        .
        .
        .
        self.WorkerFinished.emit()

И теперь все работает как положено.

Если кто-то обнаружит проблему с этим кодом, пожалуйста, сообщите мне.

Спасибо!

Другие вопросы по теме