Как я могу реализовать индикатор выполнения во всплывающем окне , которое отслеживает ход выполнения функции из так называемого класса Worker (т. Е. Требует много времени / ресурсов процессора) задача) с помощью QThread ?
Я проверил бесчисленные примеры и учебные пособия, но тот факт, что индикатор выполнения появляется во всплывающем окне, кажется, делает все сложнее. Я полагаю, что то, что я хочу, - довольно простая вещь, но я продолжаю терпеть неудачу в этом, и у меня заканчиваются идеи.
У меня есть пример того, чего я пытаюсь достичь, который основан на этом ответе :
import sys
import time
from PyQt5.QtCore import QThread, pyqtSignal, QObject, pyqtSlot
from PyQt5.QtWidgets import QApplication, QPushButton, QWidget, QHBoxLayout, QProgressBar, QVBoxLayout
class MainWindow(QWidget):
def __init__(self):
super().__init__()
self.setWindowTitle("Widget")
self.h_box = QHBoxLayout(self)
self.main_window_button = QPushButton("Start")
self.main_window_button.clicked.connect(PopUpProgressB)
self.h_box.addWidget(self.main_window_button)
self.setLayout(self.h_box)
self.show()
class Worker(QObject):
finished = pyqtSignal()
intReady = pyqtSignal(int)
@pyqtSlot()
def proc_counter(self): # A slot takes no params
for i in range(1, 100):
time.sleep(1)
self.intReady.emit(i)
self.finished.emit()
class PopUpProgressB(QWidget):
def __init__(self):
super().__init__()
self.pbar = QProgressBar(self)
self.pbar.setGeometry(30, 40, 500, 75)
self.layout = QVBoxLayout()
self.layout.addWidget(self.pbar)
self.setLayout(self.layout)
self.setGeometry(300, 300, 550, 100)
self.setWindowTitle('Progress Bar')
self.show()
self.obj = Worker()
self.thread = QThread()
self.obj.intReady.connect(self.on_count_changed)
self.obj.moveToThread(self.thread)
self.obj.finished.connect(self.thread.quit)
self.thread.started.connect(self.obj.proc_counter)
self.thread.start()
def on_count_changed(self, value):
self.pbar.setValue(value)
if __name__ == '__main__':
app = QApplication(sys.argv)
main_window = MainWindow()
sys.exit(app.exec_())
Когда я запускаю последний (например, в PyCharm Community 2019.3), программа вылетает, и я не получаю четкого сообщения об ошибке.
При отладке хотя, похоже, это работает, так как я вижу, чего я хотел достичь:
У меня есть ряд вопросов:
- Почему он взломал sh?
- Почему это работает во время отладки?
- Могу ли я просто сдаться и реализовать индикатор выполнения (привязанный) в главном окне приложения?
- Я уже реализовывал аналогичную вещь в прошлом, но без потоков: внутри l oop рабочей функции (т. Е. Функции, потребляющей процессор), мне пришлось добавить
QApplication.processEvents()
, чтобы на каждой итерации индикатор выполнения эффективно обновлялся. По-видимому, неоптимально делать вещи таким образом. Это все еще лучшая альтернатива тому, чего я пытаюсь достичь сейчас?
Прошу прощения, если есть что-то очевидное, что я пропускаю, или если на это уже был дан ответ где-то (дубликат) Я не могу найти ответ на эту проблему. Заранее большое спасибо.