《Python办公Excel处理》第二节:精通openpyxl,让Excel排版与读写自动化

目录

    • 《Python办公Excel处理》第二节:精通openpyxl,让Excel排版与读写自动化
    • [1. 核心概念理解](#1. 核心概念理解)
    • [2. 读取与修改已有Excel文件](#2. 读取与修改已有Excel文件)
    • [3. 单元格格式大改造](#3. 单元格格式大改造)
      • [3.1 设置字体 (Font)](#3.1 设置字体 (Font))
      • [3.2 设置对齐方式 (Alignment)](#3.2 设置对齐方式 (Alignment))
      • [3.3 设置背景填充色 (PatternFill)](#3.3 设置背景填充色 (PatternFill))
      • [3.4 设置边框 (Border)](#3.4 设置边框 (Border))
    • [4. 调整行高与列宽](#4. 调整行高与列宽)
    • [5. 本节小结](#5. 本节小结)

专栏导读

🌸 欢迎来到Python办公自动化专栏---Python处理办公问题,解放您的双手
🏳️‍🌈 个人博客主页:请点击------> 个人的博客主页 求收藏
🏳️‍🌈 Github主页:请点击------> Github主页 求Star⭐
🏳️‍🌈 知乎主页:请点击------> 知乎主页 求关注
🏳️‍🌈 CSDN博客主页:请点击------> CSDN的博客主页 求关注
👍 该系列文章专栏:请点击------>Python办公自动化专栏 求订阅
🕷 此外还有爬虫专栏:请点击------>Python爬虫基础专栏 求订阅
📕 此外还有python基础专栏:请点击------>Python基础学习专栏 求订阅
文章作者技术和水平有限,如果文中出现错误,希望大家能指正🙏
❤️ 欢迎各位佬关注! ❤️

《Python办公Excel处理》第二节:精通openpyxl,让Excel排版与读写自动化

在第一节课中,我们体验了如何用Python快速创建一个Excel文件。但在实际工作中,我们往往需要对已有的Excel文件进行读取、修改,甚至要设置漂亮的格式(加粗、标红、加边框等)。

本节课,我们将深入学习 openpyxl 库,帮你彻底搞定Excel的基础读写与排版操作!

1. 核心概念理解

在使用openpyxl时,必须掌握三个核心概念,它们的层级关系如下:

  1. Workbook (工作簿):代表整个Excel文件。
  2. Worksheet (工作表):代表Excel文件中的一个Sheet页。
  3. Cell (单元格):代表Sheet页中的某一个小格子(如A1, B2)。

操作Excel的基本流程:打开Workbook -> 选择Worksheet -> 操作Cell -> 保存Workbook。

2. 读取与修改已有Excel文件

假设我们有一个名为 data.xlsx 的文件,里面有一张"成绩表"。

python 复制代码
import openpyxl

# 1. 加载已存在的Excel文件
wb = openpyxl.load_workbook("data.xlsx")

# 2. 获取工作表
# 获取所有sheet的名字: print(wb.sheetnames)
sheet = wb["成绩表"]

# 3. 读取单元格的值
cell_val = sheet["B2"].value
print(f"B2单元格的值是: {cell_val}")

# 4. 修改单元格的值
sheet["C2"] = 98

# 5. 遍历多行数据
for row in sheet.iter_rows(min_row=2, max_row=5, min_col=1, max_col=3, values_only=True):
    print(row) # 输出每一行的数据元组

# 6. 保存修改(注意:如果在打开状态下保存会报错,请先关闭Excel软件)
wb.save("data_modified.xlsx")

3. 单元格格式大改造

给领导看的报表,格式必须清晰美观。openpyxl提供了 styles 模块来处理格式。

3.1 设置字体 (Font)

python 复制代码
from openpyxl.styles import Font

# 设置字体为微软雅黑,大小14,加粗,红色
custom_font = Font(name="微软雅黑", size=14, bold=True, color="FF0000")
sheet["A1"].font = custom_font

3.2 设置对齐方式 (Alignment)

python 复制代码
from openpyxl.styles import Alignment

# 设置水平居中、垂直居中
align = Alignment(horizontal="center", vertical="center")
sheet["A1"].alignment = align

3.3 设置背景填充色 (PatternFill)

python 复制代码
from openpyxl.styles import PatternFill

# 设置背景色为纯色填充,黄色 (Hex颜色代码)
fill = PatternFill(fill_type="solid", start_color="FFFF00")
sheet["A1"].fill = fill

3.4 设置边框 (Border)

python 复制代码
from openpyxl.styles import Border, Side

# 定义细边框线条
thin_line = Side(border_style="thin", color="000000")

# 设置上下左右四个边框
border = Border(left=thin_line, right=thin_line, top=thin_line, bottom=thin_line)
sheet["A1"].border = border

4. 调整行高与列宽

有时候数据太长显示为 ###,我们需要用代码自动调整宽高:

python 复制代码
# 设置第一行的行高为 30
sheet.row_dimensions[1].height = 30

# 设置A列的列宽为 20
sheet.column_dimensions["A"].width = 20

5. 本节小结

这节课我们掌握了 openpyxl 的核心技能,从文件的加载、数据的读写,到字体、对齐、背景、边框的全面美化。利用这些功能,你已经可以写出一个自动给日报/周报排版格式的脚本了。

但如果你有10万条数据需要筛选、统计,openpyxl的速度可能会有点慢。下一节课,我们将引入真正的数据处理大杀器 ------ pandas!敬请期待。

结尾

希望对初学者有帮助;致力于办公自动化的小小程序员一枚
希望能得到大家的【❤️一个免费关注❤️】感谢!
求个 🤞 关注 🤞 +❤️ 喜欢 ❤️ +👍 收藏 👍
此外还有办公自动化专栏,欢迎大家订阅:Python办公自动化专栏
此外还有爬虫专栏,欢迎大家订阅:Python爬虫基础专栏
此外还有Python基础专栏,欢迎大家订阅:Python基础学习专栏
相关推荐
qq_349317482 小时前
如何在 Go 中安全高效地将 SSH 公钥复制到远程服务器
jvm·数据库·python
zhangrelay2 小时前
三分钟云课实践速通--概率统计--python版
linux·开发语言·笔记·python·学习·ubuntu
龙腾AI白云2 小时前
大模型部署资源不足?轻量化部署解决方案
python·数据挖掘
我不是立达刘宁宇2 小时前
CORS(跨原产资源共享)靶场1
python·http
雅斯驰2 小时前
工业自动化、物联网传感器、车身控制:PIC18F26K20-I/ML的典型应用场景
运维·物联网·自动化
Xidaoapi2 小时前
Python调用OpenAI API完整教程:从零到精通
python
张赐荣2 小时前
深入详解在 Python 中用 ctypes 调用 Windows API 清空回收站
开发语言·windows·python
djjdjdjdjjdj2 小时前
如何配置外键的ON DELETE CASCADE_删除父记录自动清理子记录的级联设置
jvm·数据库·python
rannn_1112 小时前
【FastAPI|快速入门】第一个FastAPI程序、路由、参数、相应类型、自定义响应数据格式、异常响应处理
python·ai·fastapi·web·开发