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

相关推荐
铉铉这波能秀15 小时前
LeetCode Hot100 中 enumerate 函数的妙用(2026.2月版)
数据结构·python·算法·leetcode·职场和发展·开发
毕设源码-赖学姐15 小时前
【开题答辩全过程】以 基于python的电影推荐系统为例,包含答辩的问题和答案
开发语言·python
敲键盘的生活15 小时前
MoneyPrinter重构之一:用nicegui调用大模型生成视频文案
python·重构·aigc·ai编程·ai写作
qq_2975746715 小时前
【实战】POI 实现 Excel 多级表头导出(含合并单元格完整方案)
java·spring boot·后端·excel
小邓睡不饱耶15 小时前
2026 CSDN榜单封神!3大热门技术+5个大厂案例,新手也能直接抄作业
python·ai
南极星100515 小时前
我的创作纪念日--128天
java·python·opencv·职场和发展
码界筑梦坊15 小时前
327-基于Django的兰州空气质量大数据可视化分析系统
python·信息可视化·数据分析·django·毕业设计·数据可视化
Highcharts.js15 小时前
如何使用Highcharts SVG渲染器?
开发语言·javascript·python·svg·highcharts·渲染器
啊阿狸不会拉杆15 小时前
《机器学习导论》第 7 章-聚类
数据结构·人工智能·python·算法·机器学习·数据挖掘·聚类
摇滚侠15 小时前
Java,举例说明,函数式接口,函数式接口实现类,通过匿名内部类实现函数式接口,通过 Lambda 表达式实现函数式接口,演变的过程
java·开发语言·python