Ответы пользователя по тегу Qt
  • Как правильно остановить поток QThread?

    @Sergey6661313
    *учительским тоном:
    Ежели check_docs выполняется один раз, и функции в нём работают исключительно с глобальными переменными, и содержит он всего лишь одну функцию, и вы запускаете в нём другой поток (sched.scheduler) нафига вам тогда вообще QThread??? да и вообще зачем в нутри get_docs пытаться перезапустить таймер который его вызвал? ведь ваш get_docs так и останется в стеке памяти а через ебалион циклов он просто выведет ошибка рекурсии, потому что будет бесконечно ожидать когда же комманды в цикле комманд (s.enter -> s.enter -> s.enter -> s.enter и т.д.) вдруг закончатся... И почему бы вам не написать нам вывод вашей ошибки в консоль?

    *обычным голосом:
    ладно теперь серьёзно - раз уж используете pyqt то используйте на всю катушку!:
    class МойПервыйТаймерНаQt(QtCore.QObject):
        def __init__(self):
            super().__init__()
            self.basictimer = QtCore.QBasicTimer()
            self.basictimer.start(2000, self) # задержка в миллисекундах. 2000 для примера потому что 10 сек мне долго.
    
        def timerEvent(self, QTimerEvent):
            get_docs(self)  # вы конечно можете создать обьект sched.scheduler и передавать его, но зачем?
    
    
    if __name__ == "__main__":
        app = QtGui.QApplication(sys.argv)
        main_window = main_cl()
        мой_первый_таймер_на_Qt = МойПервыйТаймерНаQt()
        sys.exit(app.exec_())


    и уберите строчку "s.enter(600, 1, get_docs, (sc,))" из get_docs
    Ответ написан
    5 комментариев
  • PyQt5 вывод результата функции в окно виджета?

    @Sergey6661313
    1) для кода есть специальная кнопочка при оформлении вопроса (3 точки и выбрать code)
    2) написали бы хотябы как именно пытались установить в форму текст. Ну например хотябы так:
    def buttonClicked(self):
            print((a[9:]))
            window.tree.setText(str(a[9:]))
            sender = self.sender()

    А потом уже код ошибки или на что он у вас там ругается...
    Ответ написан
    3 комментария
  • PyQt Как проставить connect для неизвестного количества кнопок на форме?

    @Sergey6661313
    Наверное больше никогда не буду пользоваться лямбдами. Не ожидал такого подвоха от них.

    # coding=utf-8
    
    import sys
    from PyQt4 import QtGui
    from PyQt4.QtGui import QPushButton, QTableWidget
    from PyQt4.Qt import QApplication
    window = QApplication(sys.argv)
    
    class myTable(QTableWidget):
        class MyCustomEditButton(QPushButton):
            def __init__(self, i, name):
                self.i = i
                super().__init__(name)
                self.clicked.connect(self.slot_pressed)
    
            def slot_pressed(self):
                window.tableWidget.StartStop(self.i)
    
    
        def __init__(self):
            super().__init__()
            self.data = [
                ["1 строка"],
                ["2 строка"],
                ["3 строка"],
                ["4 строка"],
                ["5 строка"]
            ]
            self.datacount = len(self.data)
            self.setColumnCount(len(self.data[0])+1)
            self.setRowCount(self.datacount)
    
            for i in range(self.datacount):
                btn = self.MyCustomEditButton(i, "Edit")
    
                self.data0 = str(self.data[i][0])
                self.setItem(i, 0, QtGui.QTableWidgetItem(self.data0))
                self.setCellWidget(i, 1, btn)
    
        def StartStop(self, bb):
            print(bb)
    
    
    window.tableWidget = myTable()
    window.tableWidget.show()
    window.exec()


    Пробуйте, разбирайте. Вообще странное поведение питона. Как то не инстинктивно.
    Ответ написан
    Комментировать
  • Почему при вызове setHtml программа вылетает?

    @Sergey6661313
    res = requests.get('http://URL/'+trek+".html")
    orly?
    ну ей богу написали хотя бы "yandex.ru/index.html" для примера.

    без объяснения причин
    ну пожалуйста пользуйтесь pycharm - есть бесплатная редакция. Он честно открывает консоль для каждой запущенной программы. В которую честно пишется причина. И которая, Самое главное, не закрывается после ошибки.

    куски кода надо делать минимальными, НО запускаемыми. например такими:
    import sys
    import requests
    import os
    from PyQt5.QtWidgets import QTextBrowser
    from PyQt5.Qt import QApplication
    from PyQt5.Qt import QThread
    
    trek = "index"
    myapp = QApplication(sys.argv)
    myapp.textBrowser = QTextBrowser()
    
    class ExperementalThread(QThread):
        def run(self):
            if os.path.exists("temp/"+trek+".html"):  # Если страница уже была ранее загружена
                with open("temp/"+trek+".html") as w:
                    myapp.textBrowser.setHtml(w.read())  # ни разу не вылетело
            else:
                res = requests.get('http://yandex.ru/'+trek+".html")
                res.encoding = 'utf-8'
                with open("temp/"+trek+".html", "w") as ri:
                    ri.write(res.text)
                myapp.textBrowser.setHtml(res.text)  # И здесь
    
    thread = ExperementalThread()
    myapp.textBrowser.show()
    thread.start()
    myapp.exec()


    и ошибка соотв. будет QObject: Cannot create children for a parent that is in a different thread.
    что значит что метод setHtml пытается для себя создать отдельный поток. А потоки из потоков создавать запретил сам батюшка Ленин ( цитата от ██.██.19██г. ).

    Значит придётся использовать сигналы и слоты.
    я создал свой класс MyQTextBrowser с наследованием QTextBrowser и сигналом signal_load_html. Который в свою очередь связал с setHTML.

    # coding=utf-8
    
    import sys, requests, os                            # импортировали,
    from PyQt5.Qt        import QApplication, QThread   # импортировали,
    from PyQt5.QtCore    import pyqtSignal              # да не
    from PyQt5.QtWidgets import QTextBrowser            # выпереимпортировали.
    
    trek = "index"                                      # ну в самом деле надо же указать чему равна ваша переменная.
    myapp = QApplication(sys.argv)                      # я угадал?
                                                        # обязательно делаем отступы перед каждым классом
    class MyQTextBrowser(QTextBrowser):                 # создаём класс и наследуем QTextBrowser
        signal_load_html = pyqtSignal(str)              # назначаем сигнал (сигнал принимает значение str (строки) )
                                                        # тут тоже отступ
        def __init__(self):                             # переназначаем метод создания объектов
            super().__init__()                          # наследуем/выполняем QTextBrowser.__init__(self)
            self.signal_load_html.connect(self.setHtml) # тут связываем наш сигнал с setHtml
    myapp.textBrowser = MyQTextBrowser()                # ну и создаём вообщемто обьект нашего класса MyQTextBrowser
                                                        # обязательно делаем отступы после каджого класса.
                                                        # обязательно делаем отступы перед каждым классом
    class ExperementalThread(QThread):                  # названия придумываем на ходу
        def run(self):                                  # init не нужен сразу run
            if os.path.exists("temp/"+trek+".html"):    # Если страница уже была ранее загружена
                with open("temp/"+trek+".html") as w:   # открываем наш фаил в папке temp
                    # myapp.textBrowser.setHtml(w.read())  # вылетает? у меня кстати нет, но я читер :)
                    myapp.textBrowser.signal_load_html.emit(w.read())  # ни разу не вылетело.
            else:                                       # люблю когда много коментариев в коде
                res = requests.get('http://yandex.ru/'+trek+".html") # "Люблю говорить - это помогает думать."
                res.encoding = 'utf-8'                  # -- Томас Стернз Элиот
                with open("temp/"+trek+".html", "w") as ri: # когда этот код уже кончится?
                    ri.write(res.text)                  # тут пусто потому что в оригинале у вас был "URL" а не yandex
                # myapp.textBrowser.setHtml(res.text)   # И здесь
                myapp.textBrowser.signal_load_html.emit(res.text)  # ни разу не вылетело
                                                        # обязательно делаем отступы после каждого класса.
    thread = ExperementalThread()                       # создаём наш поток
    myapp.textBrowser.show()                            # ах да - самое главное показать окно. Иначе ничего не произойдёт
    thread.start()                                      # запускаем поток
    myapp.exec()                                        # Ой, всё!()


    p.s.
    Вообще setHtml не метод QTextBrowser. Это метод из QTextEdit (который QTextBrowser наслеует. ) Сам же QTextBrowser создан для того чтобы самостоятельно загружать и показывать страницы с интернета. (по урлу.)
    Ответ написан
    1 комментарий
  • Как в PyQt4 сделать, чтобы поток слышал сигнал от GUI?

    @Sergey6661313
    код не смотрел но:
    self.emit - переводя на русский получается послать сигнал себе.
    self.worker.emit - должно сработать...

    А вообще на до делать по современному (в reference guide отлично расписано, жалко что только по английски. ):
    class MainWindow(QtGui.QMainWindow):
        ...ваша простыня...
        def stop(self):  # остановка
            self.worker.stoping.emit() # да-да просто обрящяемся к сигналу stoping
            self.doneChecking()  # изменяем состояние виджетов гуи
        ... остальные куски вашей простыни...
    
    
    class Worker(QtCore.QObject): 
        stoping = pyqtSignal()   # сообственно наш сигнал. инициализировать нужно именно тут а не в init это важно, но я хз почему. Может ругнутся на то что не видит  pyqtSignal - тут зависит от того как вы импортировали qt и какая у вас версия его. QtCore.pyqtSignal() или QtCore.Qt.pyqtSignal() пробуйте сами короче.
        
        def __init__(self):
            super().__init__() 
            self.stoping.connect(self.stopFlag) # соединяем наш сигнал с вашим методом.
    
        ...остальная часть вашего кода...

    другие сигналы аналогично.
    и последнее мне кажется что в методе run нужно
    while self.exiting:
    иначе через час работы процесс просто завершится. (хотя может так и задумано?)

    и вообще в проверке if not self.exiting: # пока не нажали кнопку Stop.
    если не сделать
    else:
        return

    то выше назначенный цикл for продолжит свою работу просто игнорируя все записи.
    Ответ написан
    Комментировать