Python 办公自动化入门:玩转 Excel 与 Word

Python 办公自动化入门:玩转 Excel 与 Word

为什么用 Python?

  • 免费、跨平台,配合大量成熟库(openpyxlpython-docx 等),适合做"批量、重复、格式要求高"的办公任务。
  • 与手工操作相比,可重复、可追溯,尤其适合每周/每月生成报表、合同、贺卡等。

一、环境准备
  • 安装 Python(建议 3.10+),运行 python --version 确认。
  • 创建虚拟环境:
    python -m venv venv && venv\Scripts\activate
  • 安装常用库:
    pip install openpyxl python-docx pandas pillow

二、Excel 基础操作(以 openpyxl 为例)
  1. 创建与写入
python 复制代码
from openpyxl import Workbook

wb = Workbook()
ws = wb.active
ws.title = "销售日报"
ws["A1"] = "日期"
ws["B1"] = "销量"
ws.append(["2025-09-15", 188])
wb.save("sales.xlsx")
  1. 读写单元格、批量填充
python 复制代码
from openpyxl import load_workbook

wb = load_workbook("sales.xlsx")
ws = wb["销售日报"]
for row in ws.iter_rows(min_row=2, values_only=True):
    print(row)
ws["C1"] = "备注"
ws["C2"] = "旺季"
wb.save("sales.xlsx")
  1. 样式与图表
python 复制代码
from openpyxl.styles import Font, Alignment
from openpyxl.chart import LineChart, Reference

header = Font(bold=True, color="FFFFFF")
ws["A1"].font = header
ws["A1"].fill = PatternFill("solid", fgColor="4F81BD")
ws["A1"].alignment = Alignment(horizontal="center")

chart = LineChart()
chart_data = Reference(ws, min_col=2, min_row=1, max_row=31)
chart.add_data(chart_data, titles_from_data=True)
ws.add_chart(chart, "E2")
wb.save("sales.xlsx")
  • 常见需求:批量导入 CSV→Excel、按条件高亮、月度汇总。
  • 若熟悉 pandas,可先用 DataFrame 处理,再 to_excel() 输出。

三、Word 文档操作(python-docx
  1. 新建 + 段落/标题
python 复制代码
from docx import Document
from docx.shared import Pt

doc = Document()
doc.add_heading("月度工作报告", level=1)
p = doc.add_paragraph("本月重点:")
run = p.add_run("完成 ERP 上线")
run.bold = True
run.font.size = Pt(12)
doc.save("report.docx")
  1. 表格、图片、段落格式
python 复制代码
table = doc.add_table(rows=1, cols=3)
hdr_cells = table.rows[0].cells
hdr_cells[0].text = "项目"
hdr_cells[1].text = "负责人"
hdr_cells[2].text = "进度"
table.add_row().cells[0].text = "数据集成"

para = doc.add_paragraph("感谢支持!")
para.paragraph_format.first_line_indent = Pt(24)
doc.add_picture("logo.png", width=Pt(120))
doc.save("report.docx")
  1. 高级排版技巧
  • 自定义样式(document.styles["Normal"].font.name = "微软雅黑")保证中文显示。
  • 使用 docx.oxml 添加页面边框、分栏、首字下沉等(参考你现有的 generate_newsletter.py 思路)。
  • 插入文本框、WordArt:需要 VML 元素,可参照本项目中的 generate_mid_autumn_card.py_add_text_box_add_word_art 的写法。

四、综合实践思路
  1. Excel → Word :用 openpyxl 读取数据表,汇总后调用 python-docx 生成报告、报价单。
  2. 批量个性化 :循环联系人列表,逐个填充 Word 模板(可结合 docxtpl 做模板渲染)。
  3. 配图/二维码 :用 Pillow 生成横幅、二维码,插入 Word 或保存到 Excel;本项目的横幅生成函数就是示例。
  4. 流程自动化:写成脚本或 CLI,每次运行自动输出当期文档;配合 Windows 任务计划或 CI 做定时任务。

五、给"小白"的上手建议
  • 先做最小可用版本:能把 CSV 数据写进 Excel/Word 即可,再逐步加样式。
  • 多利用官方文档:
  • 遇到中文字体乱码,务必设置 run.font.name + run._element.rPr.rFonts.set(qn("w:eastAsia"), "字体")
  • 建议将常用操作封装成函数,便于复用。例如 create_banner()build_document()

六、拓展方向
  • xlsxwriter:更强大的 Excel 格式控制与图表;
  • docxtpljinja2:模板化合同/贺卡;
  • win32com.client:直接驱动 Office(Windows 环境限定);
  • pandas + matplotlib:做复杂数据分析后写回 Excel 或嵌入 Word。

结语:Python 办公自动化的核心在于"把重复动作写成脚本"。多参考现有示例(如你项目中两个生成器),逐渐积累自己的函数库,日常出报表、贺卡、通知即可一键完成。

相关推荐
haosend1 小时前
AI时代,传统网络运维人员的转型指南
python·数据网络·网络自动化
曲幽1 小时前
不止于JWT:用FastAPI的Depends实现细粒度权限控制
python·fastapi·web·jwt·rbac·permission·depends·abac
IVEN_19 小时前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang20 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮20 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling20 小时前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
AI攻城狮1 天前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽1 天前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健2 天前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python