IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> Python知识库 -> pyqt5一个多线程保存数据为excel的示例 -> 正文阅读

[Python知识库]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}')

  Python知识库 最新文章
Python中String模块
【Python】 14-CVS文件操作
python的panda库读写文件
使用Nordic的nrf52840实现蓝牙DFU过程
【Python学习记录】numpy数组用法整理
Python学习笔记
python字符串和列表
python如何从txt文件中解析出有效的数据
Python编程从入门到实践自学/3.1-3.2
python变量
上一篇文章      下一篇文章      查看所有文章
加:2022-04-14 23:50:39  更:2022-04-14 23:54:39 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/15 17:27:35-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码