pyqt5一个多线程保存数据为excel的示例

多线程保存示例,用到了QThread,openpyxl,进过测试使用openpyxl向Excel插入数据,四列十万行,大概两秒钟就可以完成

import os


from PyQt5.QtCore import QThread
from openpyxl import Workbook, load_workbook


# 定义一个多线程,用来保存dpd监控时出现的异常数据
class data_save(QThread):
    def __init__(self, data, filename, sheet_name):
        super(data_save, self).__init__()

        self.data = data                    # 数据包含本信道,两个邻信道的功率值,是一个list列表
        self.filename = filename            # 需要保存的文件名称
        self.sheet_name = sheet_name        # 需要保存的sheet表名

        self.init_create_dataFile()         # 线程被调用时,先判断文件是否存在,不存在就先创建一个模板

    # 初始化创建保存数据的文件-->生成一个模板
    def init_create_dataFile(self):
        if not os.path.exists(self.filename):
            wb = Workbook()                 # 使用Workbook()实例化一个对象wb,默认生成一个sheet名词的工作表
            ws = wb.active                  # 修改默认sheet表的名称,使用wb.active获取活动表,默认只有一个
            ws.title = Abnormal data
            ws.append([Time, Channel Power, Adj Lower Rel, Adj Upper Rel])      # 添加标题
            ws_1 = wb.create_sheet(Normal data, 1)
            ws_1.append([Channel Power, Adj Lower Rel, Adj Upper Rel])            # 添加标题

            wb.save(self.filename)
            wb.close()


    def run(self) -> None:
        
        直接添加新的数据
        :return:
        
        try:
            wb = load_workbook(self.filename)
            ws = wb[self.sheet_name]
            ws.append(self.data)

            wb.save(self.filename)
            wb.close()
        except Exception as e:
            print(fdpd save data exception: {e})
经验分享 程序员 微信小程序 职场和发展