《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基础学习专栏
相关推荐
云飞云共享云桌面3 分钟前
搭建10人SolidWorks云设计环境:云飞云在非标自动化工厂的实测方案
运维·服务器·网络·数据库·自动化·电脑
Urbano13 分钟前
突破品类边界:数控模板机不止制衣,枕套等家居家纺自动化生产全科普
运维·自动化
CTA量化套保25 分钟前
最新AI量化效率提升,用示例拆解练习压实路径
人工智能·python
zhiSiBuYu051728 分钟前
混合检索实战指南:关键词与向量的完美融合
人工智能·python·机器学习
weixin_4130632131 分钟前
复现 MatchED 边缘检测模型(单张图片重复8次,训练200 epoch)
python·算法·计算机视觉·边缘检测模型
许彰午38 分钟前
74_Python自动化办公之Excel操作
python·自动化·excel
用户83562907805120 小时前
Python 实现 PDF 文件加密与解密方法
后端·python
用户83562907805120 小时前
使用 Python 冻结与拆分 Excel 窗格教程
后端·python
你好潘先生1 天前
别再记命令了,用 yeero do 说句人话就能跑脚本,而且不烧 token
服务器·python·命令行
Agent_大师1 天前
WebSocket 行情重连成功,K线缺口不会自动消失
python