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

在使用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代码:

csharp 复制代码
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为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代码:

csharp 复制代码
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为Excel单元格设置图案填充

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

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

Python代码:

csharp 复制代码
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()

效果图:

相关推荐
曲幽5 小时前
数据库实战:FastAPI + SQLAlchemy 2.0 + Alembic 从零搭建,踩坑实录
python·fastapi·web·sqlalchemy·db·asyncio·alembic
warm3snow9 小时前
AI 重塑产品管理工具:从 Jira 到智能体项目经理的终极演进
人工智能·ai·excel·项目管理·飞书·产品经理·jira·协同·tapd
用户83562907805110 小时前
Python 实现 PowerPoint 形状动画设置
后端·python
ponponon11 小时前
时代的眼泪,nameko 和 eventlet 停止维护后的项目自救,升级和替代之路
python
Flittly11 小时前
【从零手写 ClaudeCode:learn-claude-code 项目实战笔记】(5)Skills (技能加载)
python·agent
敏编程11 小时前
一天一个Python库:pyarrow - 大规模数据处理的利器
python
TT_Close12 小时前
🐟 发布中心进度同步:8 个商店的上传功能开发完毕,正抓紧测试
flutter·npm·visual studio code
Flittly13 小时前
【从零手写 ClaudeCode:learn-claude-code 项目实战笔记】(4)Subagents (子智能体)
python·agent
明月_清风20 小时前
Python 装饰器前传:如果不懂“闭包”,你只是在复刻代码
后端·python
明月_清风20 小时前
打破“死亡环联”:深挖 Python 分代回收与垃圾回收(GC)机制
后端·python