Python+PySide2:使用多线程处理界面卡死的情况

本篇主要是梳理一下,在使用 Pyside2 模块的时候,利用多线程处理页面假死【exe未响应】的问题


一、 这边举个例子吧【如下图所示】

在这里插入图片描述

  1. 测试代码如下

    class Stats():
    
        def __init__(self):
            # 从文件中加载UI定义
            super().__init__()
            qfile_stats = QFile(f'{os.getcwd()}\\thread.ui')
            qfile_stats.open(QFile.ReadOnly)
            qfile_stats.close()
    
            self.ui = QUiLoader().load(f'{os.getcwd()}\\thread.ui')
    
            # 重置倒退进度条的进度
            self.ui.progressBar.reset()
            self.ui.progressBar.setValue(0)
            
            # 按钮绑定执行方法
            self.ui.pushButton.clicked.connect(self.test_1)
    
        '''点击触发进度条增加'''
        def test_1(self):
            for i in range(1,101):
                self.ui.progressBar.setValue(i)
                time.sleep(1)
    

二、问题出现的原因

界面中,通常会有一些按钮,点击后触发事件
如去下载一个文件或做一些操作,这些操作会耗时
如果不能及时结束,主线程将会阻塞,这样界面就会出现未响应的状态


三、问题解决办法 【多线程】

优化后的代码:

res_lock = Lock()
class Stats(QObject):

    # 实例化一个信号槽函数
    progress_sigal = Signal(int)
    textBrowser_results_sigal = Signal(str)

    def __init__(self):
        # 从文件中加载UI定义
        super().__init__()
        qfile_stats = QFile(f'{os.getcwd()}\\thread.ui')
        qfile_stats.open(QFile.ReadOnly)
        qfile_stats.close()

        self.ui = QUiLoader().load(f'{os.getcwd()}\\thread.ui')
        # 重置倒退进度条的进度
        self.ui.progressBar.reset()
        self.ui.progressBar.setValue(0)
        self.ui.pushButton.clicked.connect(self.test_1)

        # 使用到了 lambda 函数,信号槽函数连接方法
        self.progress_sigal.connect(lambda x: self.ui.progressBar.setValue(x))
        self.textBrowser_results_sigal.connect(lambda y: self.ui.textBrowser.append(y))

    '''点击触发进度条增加'''
    def test_1(self):
        for i in range(0,101,5):
            # 操作共享数据前,申请获取锁
            res_lock.acquire()
            self.ui.progressBar.setValue(i)
            # 发射信号,通知 UI 更新
            self.textBrowser_results_sigal.emit(f"当前进度:{i}%")
            time.sleep(0.1)
            # 发射信号,通知 UI 更新
            self.progress_sigal.emit(i)
            # 操作共享数据后,释放锁
            res_lock.release()

四、效果实现

在这里插入图片描述

  • 1
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Python使用PySide6实现读取文件时的环形进度条,可以按照以下步骤进行操作: 1. 首先,确保已经安装了PySide6库。可以使用以下命令进行安装: ```shell pip install PySide6 ``` 2. 创建一个Python脚本,并导入必要的模块: ```python from PySide6.QtWidgets import QApplication, QMainWindow, QProgressBar from PySide6.QtCore import Qt, QThread, Signal ``` 3. 创建一个自定义的线程类,用于模拟文件读取的进度: ```python class FileReadThread(QThread): progressChanged = Signal(int) def run(self): total_size = 1000 # 假设文件总大小为1000 for i in range(total_size): self.progressChanged.emit(i) self.msleep(10) # 模拟读取文件的延迟 ``` 4. 创建一个主窗口类,并在其中添加一个环形进度条: ```python class MainWindow(QMainWindow): def __init__(self): super().__init__() self.setWindowTitle("文件读取进度") self.resize(300, 200) self.progress_bar = QProgressBar(self) self.progress_bar.setGeometry(50, 50, 200, 200) self.progress_bar.setRange(0, 1000) # 设置进度条的范围 self.file_read_thread = FileReadThread() self.file_read_thread.progressChanged.connect(self.update_progress) self.file_read_thread.start() def update_progress(self, value): self.progress_bar.setValue(value) ``` 5. 创建一个应用程序对象,并运行主窗口: ```python app = QApplication([]) window = MainWindow() window.show() app.exec() ``` 这样,当运行该脚本时,会显示一个带有环形进度条的窗口,进度条会模拟文件读取的进度。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值