在日常办公中,我们经常需要处理大量的 Excel 表格。虽然用 Python 提取和写入数据非常高效,但如果交给老板或客户的表格毫无排版、密密麻麻,阅读体验将会大打折扣。
这时候,为 Excel 添加合适的**样式(Styles)**就显得尤为重要。加粗标题、标记高亮颜色、居中对齐、添加边框……这些操作都可以通过 Python 的 openpyxl 库自动完成。
本篇文章将系统地带你走进 openpyxl 的样式修改世界。无论你是编程小白还是有一定基础的学习者,只要跟着本文的步骤,都能轻松让你的自动化表格“漂亮”起来!
关注并私信给公众号:“python书籍”,可获得超高清Python办公自动化书籍《Excel Python:飞速搞定数据分析与处理》

在开始编写代码之前,我们需要确保环境已经准备就绪:
pip install openpyxlopenpyxl 中,Workbook 代表整个工作簿(Excel文件),Worksheet 代表工作表(Sheet),而 Cell 代表具体的单元格(如 A1)。在 openpyxl 中,所有的样式功能都存放在 openpyxl.styles 模块下。修改样式的核心逻辑非常简单:导入样式类 -> 实例化样式对象 -> 将其赋值给单元格的对应属性。
我们需要用到的主要样式类包括:
Font(字体)PatternFill(填充/背景色)Alignment(对齐方式)Border 和 Side(边框)下面我们逐一拆解。
我们可以修改字体的名称、大小、粗细、斜体以及颜色。
from openpyxl import Workbook
from openpyxl.styles import Font
wb = Workbook()
ws = wb.active
cell = ws['A1']
cell.value = "这是测试字体"
# 创建字体对象
# name: 字体名称, size: 字号, bold: 加粗, italic: 斜体, color: 16进制颜色代码(不带#)
custom_font = Font(name='微软雅黑', size=14, bold=True, italic=True, color='FF0000')
# 将字体应用到单元格
cell.font = custom_font想给重要的数据加上背景色高亮?使用 PatternFill。
from openpyxl.styles import PatternFill
cell = ws['B1']
cell.value = "高亮背景"
# fill_type='solid' 表示纯色填充,fgColor 设置前景色(即背景显示的颜色)
custom_fill = PatternFill(fill_type='solid', fgColor='FFFF00') # 纯黄背景
cell.fill = custom_fill调整文字的水平居中、垂直居中,或者设置自动换行。
from openpyxl.styles import Alignment
cell = ws['C1']
cell.value = "居中对齐\n自动换行"
# horizontal: 水平对齐 (center, left, right)
# vertical: 垂直对齐 (center, top, bottom)
# wrap_text: 自动换行 (True/False)
custom_alignment = Alignment(horizontal='center', vertical='center', wrap_text=True)
cell.alignment = custom_alignment设置边框稍微复杂一点,我们需要先用 Side 定义线条的样式(粗细、颜色),然后再用 Border 将线条应用到单元格的上下左右。
from openpyxl.styles import Border, Side
cell = ws['D1']
cell.value = "带边框的单元格"
# 定义线条样式 (border_style 可以是 'thin', 'thick', 'dashed', 'dotted' 等)
thin_side = Side(border_style='thin', color='000000') # 黑色细线
# 将线条应用到边框的四个方向
custom_border = Border(left=thin_side, right=thin_side, top=thin_side, bottom=thin_side)
cell.border = custom_border让我们把上面的知识结合起来,编写一段完整的代码,生成一个带有漂亮表头的 Excel 文件。
from openpyxl import Workbook
from openpyxl.styles import Font, PatternFill, Alignment, Border, Side
defcreate_styled_excel():
# 1. 创建工作簿和工作表
wb = Workbook()
ws = wb.active
ws.title = "销售报表"
# 2. 准备表头数据
headers = ['日期', '产品名称', '销售额', '负责人']
ws.append(headers)
# 3. 定义表头样式
header_font = Font(name='黑体', size=12, bold=True, color='FFFFFF') # 白色粗体
header_fill = PatternFill(fill_type='solid', fgColor='4F81BD') # 蓝色背景
header_align = Alignment(horizontal='center', vertical='center') # 居中对齐
thin_side = Side(border_style='thin', color='000000')
header_border = Border(left=thin_side, right=thin_side, top=thin_side, bottom=thin_side)
# 4. 循环遍历第一行的单元格,应用样式
for cell in ws[1]:
cell.font = header_font
cell.fill = header_fill
cell.alignment = header_align
cell.border = header_border
# 顺便调整一下列宽,让表格更美观
ws.column_dimensions[cell.column_letter].width = 15
# 5. 保存文件
wb.save("Styled_Report.xlsx")
print("Excel文件生成成功,样式已应用!")
if __name__ == "__main__":
create_styled_excel()对于初学者来说,在使用 openpyxl 设置样式时,经常会遇到以下几个“坑”:
# 号:在 HTML/CSS 中,颜色通常写成 #FF0000。但在 openpyxl 中,颜色参数采用的是 aRGB 十六进制格式,必须省略 # 号(例如:直接写 FF0000 代表红色)。ws['A1:D1'].font = font。如果你想给多个单元格设置样式,必须使用 for 循环遍历每一个单元格并分别赋值(如上方综合实战代码所示)。Font 对象赋值给了一个单元格,如果你想改变其中一个属性,不能直接修改 cell.font.bold = True。你需要重新创建一个新的 Font 对象并重新赋值,或者使用 copy() 方法。通过本文,我们系统地学习了如何使用 Python 和 openpyxl 库来美化 Excel 表格。从字体、背景色、对齐方式到边框,掌握了这四大核心模块,你就已经具备了制作专业级自动化报表的能力。
编程是一门实践的艺术,建议你立即打开代码编辑器,将本文的实战代码运行一遍,并尝试修改其中的颜色和字体,看看会发生什么变化。
进阶学习资源推荐:
祝你在 Python 办公自动化的道路上越走越远,效率翻倍!