《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基础学习专栏
相关推荐
汪汪大队u18 小时前
基于 K8s 的物联网平台运维体系:Ansible+Zabbix 自动化监控与故障自愈(一)—— 环境准备与 Zabbix Server 部署
运维·kubernetes·自动化·ansible·zabbix
AI技术控18 小时前
ReAct 论文解读:大模型 Agent 如何通过“推理 + 行动”完成复杂任务
人工智能·python·语言模型·自然语言处理·nlp
wang3zc18 小时前
如何设置密码复杂度策略以约束MongoDB用户的密码强度
jvm·数据库·python
紫洋葱hh18 小时前
LangChain 结构化输出详解:彻底告别大模型文本手动解析
人工智能·python·ai·langchain·llm·agent·大模型应用开发
weelinking1 天前
【2026】08_Claude与版本控制:Git协作技巧
数据库·人工智能·git·python·数据挖掘·交互·cloudera
scan7241 天前
智能体多个工具调用
python
2401_867623981 天前
CSS Flex布局中如何设置子元素间距_掌握gap属性的现代用法
jvm·数据库·python
即使再小的船也能远航1 天前
【Python】安装
开发语言·python
weixin_421725261 天前
Linux 编程语言全解析:C、C++、Python、Go、Rust 谁更强?
linux·python·go·c·编程语言
没有梦想的咸鱼185-1037-16631 天前
AI-Python机器学习、深度学习核心技术与前沿应用及OpenClaw、Hermes自动化编程
人工智能·python·深度学习·机器学习·chatgpt·数据挖掘·数据分析