python

关注公众号 jb51net

关闭
首页 > 脚本专栏 > python > Python Openpyxl修改单元格样式

零基础带你掌握Python Openpyxl单元格样式修改指南

作者:小庄-Python办公

在日常办公中,我们经常需要处理大量的 Excel 表格,本篇文章将系统地带你走进 openpyxl 的样式修改世界,无论你是编程小白还是有一定基础的学习者,只要跟着本文的步骤,都能轻松让你的自动化表格漂亮起来

引言

在日常办公中,我们经常需要处理大量的 Excel 表格。虽然用 Python 提取和写入数据非常高效,但如果交给老板或客户的表格毫无排版、密密麻麻,阅读体验将会大打折扣。

这时候,为 Excel 添加合适的**样式(Styles)**就显得尤为重要。加粗标题、标记高亮颜色、居中对齐、添加边框……这些操作都可以通过 Python 的 openpyxl 库自动完成。

本篇文章将系统地带你走进 openpyxl 的样式修改世界。无论你是编程小白还是有一定基础的学习者,只要跟着本文的步骤,都能轻松让你的自动化表格“漂亮”起来!

准备工作

在开始编写代码之前,我们需要确保环境已经准备就绪:

安装 Python 环境:确保你的电脑上已经安装了 Python(推荐 3.7 及以上版本)。

安装 openpyxl 库:打开你的命令行终端(Windows 用户打开 cmd 或 PowerShell,Mac 用户打开 Terminal),输入以下命令并回车:

pip install openpyxl

基础概念认知:你需要知道在 openpyxl 中,Workbook 代表整个工作簿(Excel文件),Worksheet 代表工作表(Sheet),而 Cell 代表具体的单元格(如 A1)。

核心指南:一步步修改Excel样式

openpyxl 中,所有的样式功能都存放在 openpyxl.styles 模块下。修改样式的核心逻辑非常简单:导入样式类 -> 实例化样式对象 -> 将其赋值给单元格的对应属性

我们需要用到的主要样式类包括:

下面我们逐一拆解。

1. 字体样式修改 (Font)

我们可以修改字体的名称、大小、粗细、斜体以及颜色。

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

2. 单元格填充与背景色 (PatternFill)

想给重要的数据加上背景色高亮?使用 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

3. 对齐方式 (Alignment)

调整文字的水平居中、垂直居中,或者设置自动换行。

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

4. 边框设置 (Border & Side)

设置边框稍微复杂一点,我们需要先用 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

5. 综合实战:制作一个漂亮的表头

让我们把上面的知识结合起来,编写一段完整的代码,生成一个带有漂亮表头的 Excel 文件。

from openpyxl import Workbook
from openpyxl.styles import Font, PatternFill, Alignment, Border, Side

def create_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 设置样式时,经常会遇到以下几个“坑”:

总结与学习资源

通过本文,我们系统地学习了如何使用 Python 和 openpyxl 库来美化 Excel 表格。从字体、背景色、对齐方式到边框,掌握了这四大核心模块,你就已经具备了制作专业级自动化报表的能力。

编程是一门实践的艺术,建议你立即打开代码编辑器,将本文的实战代码运行一遍,并尝试修改其中的颜色和字体,看看会发生什么变化。

进阶学习资源推荐:

以上就是零基础带你掌握Python Openpyxl单元格样式修改指南的详细内容,更多关于Python Openpyxl修改单元格样式的资料请关注脚本之家其它相关文章!

您可能感兴趣的文章:
阅读全文