Python 为Excel单元格设置填充\背景色 (纯色、渐变、图案)

news/2024/10/18 5:59:52/

在使用Excel进行数据处理和分析时,对特定单元格进行背景颜色填充不仅能够提升工作表的视觉吸引力,还能帮助用户快速识别和区分不同类别的数据,增强数据的可读性和理解性。
本文将通过以下三个示例详细介绍如何使用Python在Excel中设置不同的单元格背景:

文章目录

    • Python为Excel单元格设置纯色填充
    • Python为Excel单元格设置渐变色填充
    • Python为Excel单元格设置图案填充

本文需要用到一款用于操作Excel文档的第三方Python库- Spire.XLS for Python。可以下载产品包后再从本地路径安装使用,也可以直接使用以下pip命令安装:

pip install Spire.XLS

Python为Excel单元格设置纯色填充

Spire.XLS for Python库支持给某个指定的单元格或者一整个单元格区域添加纯色背景。主要步骤如下:

  1. 加载Excel文档,并获取指定工作表;
  2. 通过Worksheet.Range[]属性获取指定单元格或单元格区域;
  3. 通过 CellRange.Style.Color 属性设置背景颜色;
  4. 使用Workbook.SaveToFile()方法保存Excel文件。

Python代码:

from spire.xls import *
from spire.xls.common import *# 加载Excel文件
workbook = Workbook()
workbook.LoadFromFile("C:\\Users\\Administrator\\Desktop\\库存2.xlsx")# 获取第一张工作表
worksheet = workbook.Worksheets[0]# 给单元格或单元格区域设置背景填充色
worksheet.Range["A1:H1"].Style.Color = Color.get_SkyBlue()
worksheet.Range["D5"].Style.Color = Color.get_Red()# 保存结果文件
workbook.SaveToFile("纯色填充.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

效果图:
Python单元格背景色

Python为Excel单元格设置渐变色填充

要为单元格填充渐变色(双色),需要将填充效果设置为渐变,然后指定前景色+背景色,以及底纹样式。主要步骤如下:

  1. 加载Excel文档,并获取指定工作表;
  2. 通过Worksheet.Range[]属性获取指定单元格或单元格区域;
  3. 通过CellRange.Style.Interior属性获取单元格内部样式;
  4. 通过 ExcelInterior.FillPattern 属性指定单元格的填充效果;
  5. 通过 ExcelInterior.Gradient.BackColorExcelInterior.Gradient.ForeColor 属性设置背景色和前景色。
  6. 通过 CellStyle.Interior.FillPattern 属性指定底纹样式;
  7. 使用Workbook.SaveToFile()方法保存Excel文件

Python代码:

from spire.xls import *
from spire.xls.common import *# 加载Excel文件
workbook = Workbook()
workbook.LoadFromFile("C:\\Users\\Administrator\\Desktop\\库存2.xlsx")# 获取第一张工作表
worksheet = workbook.Worksheets[0]# 获取指定区域单元格样式
cellStyle = worksheet.Range["B4:E7"].Style# 将单元格填充效果设置为渐变
cellStyle.Interior.FillPattern  = ExcelPatternType.Gradient# 设置前景色和背景色
cellStyle.Interior.Gradient.BackColor = Color.get_Purple()
cellStyle.Interior.Gradient.ForeColor = Color.get_White()# 设置底纹样式
cellStyle.Interior.Gradient.GradientStyle = GradientStyleType.From_Corner# 保存结果文件
workbook.SaveToFile("双色填充.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

效果图:
Python单元格渐变背景

Python为Excel单元格设置图案填充

除了在单元格中填充背景颜色外,也能填充Excel中预定义的条纹、点、网格等纹理图案。主要步骤如下:

  1. 加载Excel文档,并获取指定工作表;
  2. 通过Worksheet.Range[]属性获取指定单元格或单元格区域;
  3. 通过 CellRange.Style.FillPattern 属性设置填充图案;
  4. 使用Workbook.SaveToFile()方法保存Excel文件。

Python代码:

from spire.xls import *
from spire.xls.common import *# 加载Excel文件
workbook = Workbook()
workbook.LoadFromFile("C:\\Users\\Administrator\\Desktop\\库存2.xlsx")# 获取第一张工作表
worksheet = workbook.Worksheets[0]# 给单元格或单元格区域设置背景填充图案
worksheet.Range["B1"].Style.FillPattern = ExcelPatternType.ThinDiagonalStripe
worksheet.Range["G2:H12"].Style.FillPattern = ExcelPatternType.Percent125Gray# 保存结果文件
workbook.SaveToFile("图案填充.xlsx", ExcelVersion.Version2016)
workbook.Dispose()

效果图:
Python单元格填充图案


http://www.ppmy.cn/news/1508869.html

相关文章

挖矿木马简介

挖矿木马简介 • 挖矿(Mining),早期与比特币有关,用户使用个人计算机下载软件,然后运行特定的算法,与远方服务器通信后得到相应比特币,挖矿就是利用比特币挖矿赚取比特币 • 由于挖矿成本过于…

Spring Boot集成protobuf快速入门Demo

1.什么是protobuf? Protobuf(Protocol Buffers)是由 Google 开发的一种轻量级、高效的数据交换格式,它被用于结构化数据的序列化、反序列化和传输。相比于 XML 和 JSON 等文本格式,Protobuf 具有更小的数据体积、更快…

Spring MVC 扩展和SSM框架整合

Spring MVC框架处理JSON数据 JSON格式数据在现阶段的web项目开发中扮演着非常重要的角色。在前端页面和后台交互的过程中,需要一种格式清晰、高效且两端都可以轻松使用的数据格式做交互的媒介,JSON正可以满足这一需求 JSON(JavaScript Object…

【随笔】Java 连接操作FTP与SFTP 详细指南

引言 在Java开发中,文件传输协议(FTP)和安全文件传输协议(SFTP)是处理文件传输的两种常见方式。FTP是标准的网络文件传输协议,而SFTP则在FTP基础上增加了安全层(SSH),提…

4章8节:用R做数据重塑,行列命名和数据类型转换

在R语言中,行列命名和数据类型转换是数据处理中的两个基础性操作。它们不仅对数据的可读性和组织性至关重要,而且在执行数据分析、模型构建和结果解释时也扮演着重要的角色。 一、行和列命名 在数据科学和统计分析中,命名是组织和管理数据的一个重要部分。尤其是在处理复杂…

LVS的12种调度算法详解

1.lvs调度算法类型 1.1静态方法 仅根据算法本身进行调度,不考虑RS的负载情况 1.2动态方法 主要根据每RS当前的负载状态及调度算法进行调度Overheadvalue较小的RS将被调度 1.1lvs静态调度算法 1.1.1RR(轮询算法): roundrobin 轮…

媒体优质翻译对中国产品在美国推广的影响

随着中国公司越来越多地瞄准美国市场,媒体内容的高质量翻译的重要性怎么强调都不为过。有效地翻译不仅仅是将单词从一种语言转换为另一种语言;这是关于传达正确的信息、语气和文化细微差别。高质量的翻译通过提高品牌知名度、增加客户参与度和推动销售&a…

cAdvisor+prometheus+grafana搭建监控页面并嵌入自定义页面中

三者关系 一般公司会有很多docker主机,那么就需要对docker进行监控了,docker监控可以采用docker stats配合shell命令来取值做监控,但是无法传递给prometheus进行采集,zabbix监控docker又比较麻烦,因此就有了谷歌的cad…