Python使用设计模式中的建筑模式将数据写入Excel且满足条件内容标红

news/2024/5/15 16:49:36

对于这个任务,适合使用"Builder"设计模式。Builder模式的主要目的是将对象的构建与其表示分离,以便相同的构建过程可以创建不同的表示。在这个情况下,我们需要一个构建器来逐行构建Excel表格,并根据给定的数据添加相应的统计结果。

下面是一个简单的示例,展示了如何使用Builder模式来实现这个功能:


import pandas as pd# 定义构建器类
class ExcelBuilder:def __init__(self, headers):self.headers = headersself.result_df = pd.DataFrame(columns=headers) # 定位DataFrame中下一个可用的行def add_row(self, data):self.result_df.loc[len(self.result_df)] = datadef export_excel(self, filename):excel_writer = pd.ExcelWriter(filename, engine='xlsxwriter')self.result_df.to_excel(excel_writer, index=False, sheet_name='Sheet1')# 获取工作簿和工作表对象workbook = excel_writer.bookworksheet = excel_writer.sheets['Sheet1']# 添加条件格式:将值大于25的单元格标红red_format = workbook.add_format({'bg_color': '#FFC7CE', 'font_color': '#9C0006'})worksheet.conditional_format('B2:D1000', {'type': 'cell', 'criteria': '>', 'value': 25, 'format': red_format})# excel_writer.save()excel_writer.close()print("Excel表格已生成")# 使用构建器来构建Excel表格
headers = ['类别', '结果1', '结果2', '结果3']
excel_builder = ExcelBuilder(headers)# 假设这是你的统计结果,以列表形式存储
statistics = [['A', 10, 20, 30],['B', 15, 25, 35],['C', 20, 30, 40],['D', 20, 30, "4a"]
]# 逐行添加统计结果
for row in statistics:excel_builder.add_row(row)# 导出Excel表格
excel_builder.export_excel('统计结果.xlsx')

运行结果

在这个示例中,我们首先定义了一个`ExcelBuilder`类,用于构建Excel表格。该类有三个方法:`__init__`用于初始化构建器,`add_row`用于逐行添加统计结果,`export_excel`用于将构建好的Excel表格导出到文件中。然后,我们使用构建器来创建Excel表格并逐行添加统计结果,最后导出到文件中。

self.result_df = pd.DataFrame(columns=headers)这行代码是用于将数据逐行添加到DataFrame中的。让我一步一步解释:
  1. self.result_df 是一个DataFrame对象,它存储着我们的统计结果数据。

  2. len(self.result_df) 返回DataFrame中已有的行数。

  3. self.result_df.loc[len(self.result_df)] 是用来定位DataFrame中下一个可用的行,并将数据添加到这一行中。

  4. = data 则是将data变量中的数据赋值给这一行,这样就完成了一行数据的添加操作。

综合起来,这行代码的作用是将数据逐行添加到DataFrame中的下一个可用行中。

worksheet.conditional_format('B2:D1000', {'type': 'cell', 'criteria': '>', 'value': 25, 'format': red_format})这行代码是用来设置 Excel 工作表中的条件格式的。让我解释一下参数的含义:
  • 'B2:D1000':这是条件格式应用的范围。它指定了要应用条件格式的单元格范围,从 B2 到 D1000。
  • {'type': 'cell', 'criteria': '>', 'value': 25, 'format': red_format}:这是条件格式的规则。具体含义如下:
    • 'type': 'cell':指定条件格式的类型为单元格。
    • 'criteria': '>':指定条件为大于。这意味着我们希望对满足大于某个值的单元格应用条件格式。
    • 'value': 25:这是条件的值。在本例中,条件是大于25的单元格将被标红。
    • 'format': red_format:这是应用的格式。red_format 是之前定义的红色格式,它指定了标红的背景色和字体颜色。

因此,这行代码的作用是将范围内数值大于25的单元格标记为红色。


http://www.mrgr.cn/p/86727714

相关文章

深度学习--RNN循环神经网络和LSTM

RNN RNN简介 我们来看一看百度百科给的解释 下面是循环神经网络的一部分 黑色直线代表权重,a1,a2代表存储单元,黄色框框代表输入,曲线是激活函数 RNN常用领域 语言建模(Language Modeling):…

union共用体以及如何判断大小端?

目录方法一(共用体):如何判断大小端二:方法二( 方法一(共用体): 在C语言当中,有一个和结构体非常像的语法叫共用体(Union)。 union myunion {int a;char b; }; union myunion test;在共用体中,所以成员共用一段内存,对某一个数据成员赋值,其他成员也就失效了。在…

IT维护部门的绩效考核怎么做?

又到了年末,每年一度的考核又要开始了,王经理也越来越紧张,作为公司IT系统维护部门的领导,他是有苦说不出。 费力不讨好 在公司里,维护部门一直是一个弱势部门,人数不少,整天也没闲着,围着公司团团转,一旦有需求还都是急活,各个都是领导,真是忙的脚打后脑勺。可是…

中国首个Sora级视频大模型Vidu震撼发布

北京时间2024年4月27日,在2024中关村论坛年会未来人工智能先锋论坛上,清华大学联合生数科技27日正式发布中国首个长时长、高一致性、高动态性视频大模型——Vidu。 该模型采用团队原创的Diffusion与Transformer融合的架构U-ViT,支持一键生成长…

H2 Database Console未授权访问

H2 Database Console未授权访问 H2 database是一款java内存数据库,多用于单元测试。H2 database自带一个web管理页面,在Spring开发中,如果我们设置如下选项,即可允许外部用户访问WEB管理页面,且没有鉴权; spring.h2.console.enabled=true spring.h2.console.settings.web…

SpringBoot配置HTTPS及开发调试

前言 在实际开发过程中,如果后端需要启用https访问,通常项目启动后配置nginx代理再配置https,前端调用时高版本的chrome还会因为证书未信任导致调用失败,通过摸索整理一套开发调试下的https方案,特此分享 后端配置 生成HTTPS密钥 keytool -genkeypair -alias tomcat -keya…

C# winform 漂亮的日期时间控件

源代码下载: https://download.csdn.net/download/gaoxiang19820514/89242240 效果图在 HZH-Controls控件 基础上修改的日期控件 因为HZH_Controls控件 中的日期控件太大了, 我的程序中需要多个日期时间的控件放不下,主题是绿色的,所以手动调了一下样式。 为了和HZH_Contro…

计算机视觉 CV 八股分享 [自用](更新中......)

目录 一、深度学习中解决过拟合方法 二、深度学习中解决欠拟合方法 三、梯度消失和梯度爆炸 解决梯度消失的方法 解决梯度爆炸的方法 四、神经网络权重初始化方法 五、梯度下降法 六、BatchNorm 七、归一化方法 八、卷积 九、池化 十、激活函数 十一、预训练 十二…

Vue 组件单元测试深度探索:细致解析与实战范例大全

Vue.js作为一款广受欢迎的前端框架,以其声明式的数据绑定、组件化开发和灵活的生态系统赢得了广大开发者的心。然而,随着项目规模的增长,确保组件的稳定性和可靠性变得愈发关键。单元测试作为软件质量的守护神,为Vue组件的开发过程…

免费白嫖证件照

​痛点 直接拍证件照需要花几块钱 自己拍图去换背景掏钱,去抠图掏钱,要么有水印不高清 拍个照 首先有一张照片 ,最后白底,身上衣服和白对立的 ,比如穿个黑色衣服,站在白墙 ,拍个照片,以下为我测试用的原图 ​ 替换背景 手机下载APP (剪映) - 拿它拍照也行,高清美颜…

TiDB 6.x 新特性解读 | Collation 规则

对数据库而言,合适的字符集和 collation 规则能够大大提升使用者运维和分析的效率。TiDB 从 v4.0 开始支持新 collation 规则,并于 TiDB 6.0 版本进行了更新。本文将深入解读 Collation 规则在 TiDB 6.0 中的变更和应用。 引 这里的“引”,…

R语言中取色器 colorfindr测试

需求: 一张图片,想知道到底是什么颜色, 在R语言中的颜色系统中。 测试图片如下: 001、install.packages("colorfindr") ## 安装包 library("colorfindr") ## 加载包get_colors(img = "aa.…

1-Linux集群搭建,分发脚本,ssh免密登录

Linux集群部署集群规划模板机安装创建完成后全部打开并登录root账户修改克隆主机名 vim /etc/sysconfig/network-scripts/ifcfg-ens33 esc退出并输入:wq保存 按i修改IPADDR为192.168.10.101 / 192.168.10.102 / 192.168.10.103vim /etc/hostname 按i修改名字为kafka-broker1…

数据挖掘实验一

一、实验环境及背景 使用软件: Anaconda3 Jupyter Notebook 实验内容: 1.使用Tushare或者其他手段获取任意两支股票近三个月的交易数据。做出收盘价的变动图像。2.使用Pandas_datareader获取世界银行数据库中美国(USA)、瑞典&…

aardio爬虫) 实战篇:采集自己的公众号粉丝列表

前言 只有自己封装库的时候,才知道造轮子有多累。之前使用Python的时候,基本都只需要import,随便哪个功能都有人写好轮子用。不过造轮子也有好处,可以了解一些比较基础的知识。 其实aardio也有很多已经造好的轮子可以用,只是因为只有作者在维护,而且没有一个活跃的社区,…

微信小程序:5.数据绑定

在Data中定义数据早wxml中进行数据使用 在data中定义数据 在页面对应的js对象中找到data,然后把数据进行定义即可 Page({data: {motto: Hello World,userInfo: {avatarUrl: defaultAvatarUrl,nickName: ,},hasUserInfo: false,canIUseGetUserProfile: wx.canIUse…

【火猫体育】NBA:快船艰难击败独行侠,伦纳德成球队毒瘤?

作为西部竞争最激烈的一轮系列赛,快船在G4艰难击败了独行侠,将双方的总比分扳为2比2。本场比赛伦纳德因伤缺阵,快船却一改前两场比赛糟糕的发挥,哈登和乔治通过出色的表现带队赢下了独行侠。正所谓,赢球不可怕缺谁谁尴…

Docker——开源的应用容器的引擎

目录 一、前言 1.虚拟化产品有哪些 1.1寄居架构 1.2源生架构 2.虚拟化产品对比/介绍 2.1虚拟化产品 2.1.1仿真虚拟化 2.1.2半虚拟化 2.1.3全虚拟化 2.2重点 2.2.1KVM——Linux内核来完成的功能和性能 2.2.2ESXI——用的比较多 二、Docker概述 1.Docker定义 2.Do…

(mac)Prometheus监控之Node_exporter(CPU、内存、磁盘、网络等)

完整步骤 1.启动 Prometheus 普罗米修斯 prometheus --config.file/usr/local/etc/prometheus.yml 浏览器访问 http://localhost:9090/targets 2.启动Node_exporter node_exporter 访问:http://localhost:9100 3.启动grafana brew services start grafana 访问…

linx使用命令还原数据库(source还原方式)

进入到数据库mysql -u datatablename -p//参数解析: datatablename 是连接数据库的用户输入数据库密码: 成功进入数据库: 2、可以查看当前用户有哪些数据库权限 show databases;3、进入到指定的数据库use test;//参数解析:test-是数据库名称4、查看当前数据库所有的表show…