时间:2021-05-22
在做GUI界面时我们希望后台任务能够与UI分开,在PyQt中,主线程用来重绘界面。而子线程里边的实时处理结果需要反馈到界面,子线程里边不能执行界面更新操作。
wxpython多线程刷新界面转到
下面给出类Python3+PyQt5多线程防假死动态刷新界面的模板
from PyQt5 import QtWidgets, QtCoreimport sysfrom PyQt5.QtCore import *import time # 继承QThreadclass Runthread(QtCore.QThread): # 通过类成员对象定义信号对象 _signal = pyqtSignal(str) def __init__(self): super(Runthread, self).__init__() def __del__(self): self.wait() def run(self): for i in range(100): time.sleep(0.2) self._signal.emit(str(i)) # 注意这里与_signal = pyqtSignal(str)中的类型相同 class Example(QtWidgets.QWidget): def __init__(self): super().__init__() # 按钮初始化 self.button = QtWidgets.QPushButton('开始', self) self.button.setToolTip('这是一个 <b>QPushButton</b> widget') self.button.resize(self.button.sizeHint()) self.button.move(120, 80) self.button.clicked.connect(self.start_login) # 绑定多线程触发事件 # 进度条设置 self.pbar = QtWidgets.QProgressBar(self) self.pbar.setGeometry(50, 50, 210, 25) self.pbar.setValue(0) # 窗口初始化 self.setGeometry(300, 300, 300, 200) self.setWindowTitle('OmegaXYZ.com') self.show() self.thread = None # 初始化线程 def start_login(self): # 创建线程 self.thread = Runthread() # 连接信号 self.thread._signal.connect(self.call_backlog) # 进程连接回传到GUI的事件 # 开始线程 self.thread.start() def call_backlog(self, msg): self.pbar.setValue(int(msg)) # 将线程的参数传入进度条 if __name__ == "__main__": app = QtWidgets.QApplication(sys.argv) myshow = Example() myshow.show() sys.exit(app.exec_())效果:
以上这篇PyQt5多线程刷新界面防假死示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
PyQt5简单多线程信号与槽的使用最简单的多线程使用方法是利用QThread函数,展示QThread函数和信号简单结合的方法importsysfromPyQt5
心得:写着写着找到了自己的感觉,还是需要大量的代码和项目来加深对代码的理解一、PyQt5多线程防卡死在界面中,通常用会有一些按钮,点击后触发事件,比如去下载一个
一般在使用RecyclerView的时候不免要修改RecyclerView的数据,使用notifyDataSetChanged()来刷新界面,但是当数据比较多,
Windows8在功能上的最大亮点就是新界面及新界面应用,硬件设备驱动在新界面中也能够顺利的安装和使用。具体方法如下: 第一步:鼠标移动到右上或者右下角,
PyCharm不识别PyQt5的问题如图所示,引用PyQt5的时候显示错误“ModuleNotFoundError:Nomodulenamed'pyqt5'”首