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 中的宏代码无法直接修改)

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

相关推荐
某人辛木3 小时前
Web自动化测试
前端·python·pycharm·pytest
C+++Python3 小时前
详细介绍一下Java泛型的通配符
java·windows·python
小帅热爱难回头4 小时前
编写Skill生成AI落地项目系统架构
python
diving deep4 小时前
脚本速览-python
开发语言·python
2601_951643776 小时前
Python第一,Java跌出前三,C语言杀回来了
java·c语言·python·编程语言排行·技术趋势
AC赳赳老秦8 小时前
OpenClaw+Power Apps 实战:自动生成 Power Apps 应用、连接 Excel 数据源
大数据·开发语言·python·serverless·excel·deepseek·openclaw
茉莉玫瑰花茶9 小时前
综合案例 - AI 智能租房助手 [ 5 ]
服务器·数据库·人工智能·python·ai
文艺倾年9 小时前
【强化学习】强化学习基本概念,20W字总结(一)
人工智能·python·语言模型·自然语言处理·面试·职场和发展·大模型
宸丶一10 小时前
Day 13:持久化记忆 - 让 Agent 拥有长期记忆
jvm·python·ai
码云骑士10 小时前
13-列表append的底层真相(上)-listobject源码中的预分配策略
开发语言·python