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

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

相关推荐
程序员大雄学编程29 分钟前
用Python来学微积分23-微分中值定理
人工智能·python·数学·微积分
SunnyDays10111 小时前
如何使用Python编辑PDF文档:修改文本、添加图片、更新元数据等
python·编辑pdf·修改pdf文字
、、、、南山小雨、、、、1 小时前
加载YOLO模型,处理mp4视频
python·yolo·音视频
wshlp1234562 小时前
deepseek api 灵活使用
python
AI视觉网奇2 小时前
coco json 分类标注工具源代码
开发语言·python
要加油GW3 小时前
python使用vscode 需要配置全局的环境变量。
开发语言·vscode·python
B站计算机毕业设计之家3 小时前
python图像识别系统 AI多功能图像识别检测系统(11种识别功能)银行卡、植物、动物、通用票据、营业执照、身份证、车牌号、驾驶证、行驶证、车型、Logo✅
大数据·开发语言·人工智能·python·图像识别·1024程序员节·识别
快乐的钢镚子4 小时前
思腾合力云服务器远程连接
运维·服务器·python
苏打水com4 小时前
爬虫进阶实战:突破动态反爬,高效采集CSDN博客详情页数据
爬虫·python
夫唯不争,故无尤也4 小时前
三大AI部署框架对比:本地权重与多模型协作实战
人工智能·python·深度学习