自动化办公|通过xlwings进行excel格式设置

1. 介绍

xlwings 是一个强大的 Python 库,可以用来操作 Excel,包括设置单元格格式、调整行高列宽、应用条件格式以及使用内置样式。本文将详细介绍如何使用 xlwings 进行 Excel 格式化操作,并附带代码示例。

2. 基础格式设置(字体、颜色、边框)

2.1 设置字体和颜色

复制代码
import xlwings as xw

wb = xw.Book('example.xlsx')
sht = wb.sheets['Sheet1']

# 设置单元格字体和颜色
rng = sht.range('A1:C3')
rng.font.name = '微软雅黑'  # 字体
rng.font.size = 12         # 字号
rng.font.color = (255, 0, 0)  # 字体颜色 (RGB)
rng.api.Font.Bold = True   # 加粗

# 设置背景色
rng.color = (255, 255, 0)  # 黄色背景

2.2 设置边框

复制代码
# 设置边框
border = rng.api.Borders
border.LineStyle = 1  # 实线
border.Weight = 2     # 中等粗细
rng.api.Borders(9).LineStyle = 1  # 下边框 (9对应Excel常量xlEdgeBottom)

3. 调整行高和列宽

复制代码
# 调整行高和列宽
sht.range('A1').row_height = 25    # 设置第1行高度
sht.range('A1').column_width = 15  # 设置A列宽度

# 自动调整行高列宽
sht.range('A1:C10').autofit()      # 自动调整行高和列宽
sht.autofit('columns')             # 仅自动调整列宽

4. 应用条件格式

4.1 高亮大于100的单元格

复制代码
cf_range = sht.range('D1:D10')
cf = cf_range.api.FormatConditions.Add(
    Type=2,  # xlCellValue
    Operator=5,  # xlGreater
    Formula1="100"
)
cf.Font.Color = 0xFF0000  # 红色字体
cf.Interior.Color = 0xFFFF00  # 黄色背景

4.2 使用数据条(Data Bars)

复制代码
cf_range.api.FormatConditions.AddDatabar()
data_bar = cf_range.api.FormatConditions(1)
data_bar.BarColor.Color = 0x00B050  # 绿色数据条

5. 使用内置样式

复制代码
# 应用Excel内置样式
sht.range('A1').style = 'Good'     # 绿色背景
sht.range('B1').style = 'Bad'      # 红色背景
sht.range('C1').style = 'Neutral'  # 黄色背景

# 自定义样式
style_name = 'CustomStyle'
if style_name not in [s.Name for s in wb.api.Styles]:
    style = wb.api.Styles.Add(style_name)
    style.Font.Bold = True
    style.Interior.Color = 0x00FF00
sht.range('D1').style = style_name

6. 完整示例

复制代码
import xlwings as xw

wb = xw.Book()
sht = wb.sheets[0]

# 填充测试数据
sht.range('A1').value = [[10, 200], [150, 50]]

# 格式设置
rng = sht.range('A1:B2')
rng.font.name = 'Calibri'
rng.font.size = 12
rng.column_width = 15

# 条件格式
cf = rng.api.FormatConditions.Add(
    Type=2, Operator=5, Formula1="100"
)
cf.Interior.Color = 0x00FF00

# 保存
wb.save('formatted.xlsx')
wb.close()

7. 注意事项

  • 颜色可使用 RGB 元组 (R, G, B) 或十六进制值(需转换为整数)。

  • 部分高级功能需通过 .api 调用 Excel VBA 对象模型。

相关推荐
薛定谔的猫喵喵5 小时前
天然气压力能利用系统综合性评价平台:基于Python和PyQt5的AHP与模糊综合评价集成应用
开发语言·python·qt
yuluo_YX5 小时前
Reactive 编程 - Java Reactor
java·python·apache
独好紫罗兰5 小时前
对python的再认识-基于数据结构进行-a004-列表-实用事务
开发语言·数据结构·python
ZH15455891315 小时前
Flutter for OpenHarmony Python学习助手实战:模块与包管理的实现
python·学习·flutter
choke2336 小时前
[特殊字符] Python异常处理
开发语言·python
玄同7657 小时前
从 0 到 1:用 Python 开发 MCP 工具,让 AI 智能体拥有 “超能力”
开发语言·人工智能·python·agent·ai编程·mcp·trae
小瑞瑞acd7 小时前
【小瑞瑞精讲】卷积神经网络(CNN):从入门到精通,计算机如何“看”懂世界?
人工智能·python·深度学习·神经网络·机器学习
火车叼位7 小时前
也许你不需要创建.venv, 此规范使python脚本自备依赖
python
火车叼位7 小时前
脚本伪装:让 Python 与 Node.js 像原生 Shell 命令一样运行
运维·javascript·python
L543414467 小时前
告别代码堆砌匠厂架构让你的系统吞吐量翻倍提升
大数据·人工智能·架构·自动化·rpa