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

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

相关推荐
向宇it13 分钟前
php高性能的导出excel读写扩展——xlswriter,比传统的Spreadsheet要快很多
php·excel·xlswriter
赵侃侃爱分享18 分钟前
学完Python第一次写程序写了这个简单的计算器
开发语言·python
a95114164222 分钟前
Go语言如何操作OSS_Go语言阿里云OSS上传教程【完整】
jvm·数据库·python
2401_8971905523 分钟前
MySQL中如何利用LIMIT配合函数分页_MySQL分页查询优化
jvm·数据库·python
断眉的派大星32 分钟前
# Python 魔术方法(魔法方法)超详细讲解
开发语言·python
我的xiaodoujiao40 分钟前
API 接口自动化测试详细图文教程学习系列11--Requests模块3--测试练习
开发语言·python·学习·测试工具·pytest
Polar__Star1 小时前
C#怎么使用并发集合 C#ConcurrentDictionary和ConcurrentQueue线程安全集合怎么用【进阶】
jvm·数据库·python
TechWayfarer1 小时前
攻防对抗:利用IP段归属查询工具快速封禁攻击源——3步联动防火墙(附脚本)
python·网络协议·tcp/ip·安全
m0_493934531 小时前
Go语言中 & 与 - 的本质区别及指针使用详解
jvm·数据库·python
Greyson12 小时前
Redis如何解决哨兵通知延迟问题_优化客户端连接池动态刷新拓扑的订阅监听机制
jvm·数据库·python