多线程保存示例,用到了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(f'dpd save data exception: {e}')
|