Python办公之Excel(openpyxl)、PPT(python-pptx)、Word(python-docx)

概述

  • 以下是 Python 中处理 Office 文档的三个常用库的介绍及基础用法
  • 视频教程资料:https://pan.quark.cn/s/a2faff7aab76

1. openpyxl(处理 Excel)

用途 :专门用于读写 Excel 2010 及以上版本的 .xlsx.xlsm 文件。

核心功能

  • 创建、修改 Excel 工作簿
  • 读取和写入单元格数据
  • 设置单元格格式(字体、颜色、边框等)
  • 操作工作表(新增、删除、重命名)
  • 处理公式、图表等

简单示例

python 复制代码
from openpyxl import Workbook

# 创建工作簿
wb = Workbook()
# 获取活动工作表
ws = wb.active
# 写入数据
ws['A1'] = '姓名'
ws['B1'] = '年龄'
ws.append(['张三', 25])
ws.append(['李四', 30])
# 保存文件
wb.save('example.xlsx')

2. python-docx(处理 Word)

用途 :用于创建和修改 Word 的 .docx 文档(不支持旧版 .doc)。

核心功能

  • 创建文档、添加段落和标题
  • 设置文本格式(字体、大小、加粗、斜体等)
  • 插入表格、图片、列表
  • 调整页面布局(页边距、纸张大小等)
  • 操作页眉页脚

简单示例

python 复制代码
from docx import Document
from docx.shared import Inches

# 创建文档
doc = Document()
# 添加标题
doc.add_heading('Python 操作 Word 示例', level=1)
# 添加段落
p = doc.add_paragraph('这是一个 ')
p.add_run('加粗的').bold = True
p.add_run(' 文本段落。')
# 添加表格
table = doc.add_table(rows=2, cols=2)
table.cell(0, 0).text = '姓名'
table.cell(0, 1).text = '职业'
table.cell(1, 0).text = '张三'
table.cell(1, 1).text = '工程师'
# 保存文件
doc.save('example.docx')

3. python-pptx(处理 PowerPoint)

用途 :用于创建和修改 PowerPoint 的 .pptx 演示文稿。

核心功能

  • 创建幻灯片、设置布局
  • 添加文本框、形状、图片
  • 设置文本格式和段落样式
  • 操作幻灯片(新增、删除、重排)
  • 调整幻灯片背景、主题等

简单示例

python 复制代码
from pptx import Presentation
from pptx.util import Inches, Pt

# 创建演示文稿
prs = Presentation()
# 添加标题幻灯片
slide_layout = prs.slide_layouts[0]
slide = prs.slides.add_slide(slide_layout)
title = slide.shapes.title
subtitle = slide.placeholders[1]
title.text = "Python 操作 PPT 示例"
subtitle.text = "使用 python-pptx 库"

# 添加内容幻灯片
slide_layout = prs.slide_layouts[1]
slide = prs.slides.add_slide(slide_layout)
title = slide.shapes.title
content = slide.placeholders[1]
title.text = "主要功能"
tf = content.text_frame
tf.text = "1. 创建幻灯片\n2. 添加文本和图片\n3. 设置格式"

# 保存文件
prs.save('example.pptx')

共同点与注意事项

  • 均为第三方库,需通过 pip install 库名 安装
  • 主要支持新建和修改操作,对复杂格式的解析能力有限
  • 不支持宏文件的完全编辑(如 .xlsm 中的宏代码无法直接修改)

这些库能有效实现办公文档的自动化处理,适合批量生成报告、处理数据等场景。

相关推荐
IVEN_1 天前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang1 天前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮1 天前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling1 天前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
AI攻城狮1 天前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽1 天前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健2 天前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
码路飞2 天前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
曲幽2 天前
FastAPI压力测试实战:Locust模拟真实用户并发及优化建议
python·fastapi·web·locust·asyncio·test·uvicorn·workers