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(f'dpd save data exception: {e}')

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值