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})