📊 PPT智能管理系统
PPT管理系统,实现静态模板内容与动态数据内容的智能合并。
📚 从零开始完整教程(必读)
第一步:创建你的第一个静态PPT模板
方式A: 运行脚本快速生成示例(推荐新手)
cd f:\ppt\ppt_manager
python create_sample_template.py
✅ 自动生成: static_ppt/macro_analysis_template.pptx (23页空白模板)
方式B: 手工创建属于你自己的模板(正式项目用)
-
打开Microsoft PowerPoint → 新建空白演示文稿
-
保存到:
f:\ppt\ppt_manager\static_ppt\你的模板名称.pptx -
页面布局建议:
页码 内容类型 说明 1页 封面 static 2页 目录 static 3页 分析框架 static 4页 GDP图表页 dynamic → Python脚本生成 5页 CPI图表页 dynamic → Python脚本生成 6-23页 其他原理内容 static -
保存模板
第二步:理解 config/project_config.yaml 配置
projects:
macro_analysis: # 项目ID
name: "宏观数据分析报告" # 显示名称
static_ppt: "static_ppt/macro_analysis_template.pptx" # 模板路径 ✅
total_slides: 23 # 总页数
slide_mapping:
1: static # 第1页 = 静态来自模板
2: static # 第2页 = 静态来自模板
3: static # 第3页 = 静态来自模板
4: dynamic_chart_gdp # 第4页 = 动态执行GDP脚本生成图片插入
5: dynamic_chart_inflation # 第5页 = 动态执行CPI脚本生成图片插入
6: static
...更多...
23: static
dynamic_generators: # 动态key 到 脚本文件路径 的映射
dynamic_chart_gdp: "scripts/gdp_chart.py"
dynamic_chart_inflation: "scripts/inflation_chart.py"
dynamic_table_employment: "scripts/employment_table.py"
dynamic_chart_trade: "scripts/trade_chart.py"
dynamic_content_market: "scripts/market_analysis.py"
关键点:
slide_mapping里的 key 如果不是static,就去dynamic_generators里找对应脚本执行- 脚本返回PNG图片路径,系统把图片插入对应新生成的页面
第三步:更新动态数据(改脚本取真实数据)
打开 scripts/gdp_chart.py 改成你自己的采集逻辑:
def generate(output_dir):
import pandas as pd
# --------------------------
# 在这里替换成你真实的取数代码:
# --------------------------
# df = pd.read_sql("SELECT * FROM gdp_stats", conn)
# 或 df = pd.read_csv("你的真实GDP数据文件.csv")
# 或 API调用: requests.get("https://stats.gov.cn/api/gdp")
# 下面是示例模拟数据,跑通后替换成真实采集代码
quarters = ['2026Q1', '2026Q2']
actual_data_from_api = [5.2, 5.1]
# 生成matplotlib图
import matplotlib.pyplot as plt
plt.plot(quarters, actual_data_from_api)
plt.savefig(f"{output_dir}/my_real_gdp_chart.png")
return f"{output_dir}/my_real_gdp_chart.png"
其他脚本同理修改:
- CPI →
scripts/inflation_chart.py - 就业数据 →
scripts/employment_table.py - 贸易数据 →
scripts/trade_chart.py - 市场分析 →
scripts/market_analysis.py
第四步:启动Web生成
pip install -r requirements.txt
python app.py
浏览器打开 http://localhost:5000
点击项目卡片上的 🚀 "开始生成" 按钮
✅ 生成的PPT在 f:\ppt\ppt_manager\output\ 目录
✨ 核心特性
- 📁 静态PPT管理: 固定不变的原理内容放在本地PPT模板中
- 🔄 动态内容生成: Python脚本负责数据采集、图表生成
- 🎯 页面映射配置: YAML配置文件定义每页是静态还是动态
- 🖱️ 一键生成: Web界面点击按钮自动合成最终PPT
- 📝 日志记录: 使用loguru完整记录生成过程
📁 项目结构
ppt_manager/
├── static_ppt/ # 静态PPT模板目录
│ └── macro_analysis_template.pptx # 23页模板示例
├── config/
│ └── project_config.yaml # 项目配置:页面映射关系
├── scripts/ # 动态内容生成脚本
│ ├── gdp_chart.py # GDP图表生成
│ ├── inflation_chart.py # CPI/PPI图表
│ ├── employment_table.py # 就业数据表
│ ├── trade_chart.py # 进出口图表
│ └── market_analysis.py # 市场分析图表
├── dynamic_content/ # 动态生成的图片存放
├── output/ # 👉 最终生成的PPT在这里
├── logs/ # 日志目录
├── src/
│ ├── config_loader.py # 配置加载器
│ ├── ppt_core.py # PPT核心操作
│ ├── dynamic_generator.py # 动态内容生成器
│ └── ppt_generator.py # 主合成引擎
├── templates/
│ └── index.html # Web界面
├── app.py # Flask Web应用(端口5000)
├── main.py # 命令行入口
├── create_sample_template.py # ✅ 快速创建示例模板脚本
└── requirements.txt # Python依赖
🚀 快速开始(TL;DR)
1. 安装依赖
cd ppt_manager
pip install -r requirements.txt
2. 初始化示例静态PPT模板
python create_sample_template.py
3. 运行系统
方式一:Web界面(推荐)
python app.py
然后在浏览器打开: http://localhost:5000
方式二:命令行
python main.py macro_analysis
⚙️ 配置说明
在 config/project_config.yaml 中配置:
projects:
macro_analysis:
name: "宏观数据分析报告"
static_ppt: "static_ppt/macro_analysis_template.pptx"
total_slides: 23
slide_mapping:
1: static
2: static
3: static
4: dynamic_chart_gdp
5: dynamic_chart_inflation
...
dynamic_generators:
dynamic_chart_gdp: "scripts/gdp_chart.py"
dynamic_chart_inflation: "scripts/inflation_chart.py"
...
📝 动态脚本编写规范
每个动态脚本必须包含一个 generate(output_dir) 函数,返回生成的图片路径:
def generate(output_dir):
# 1. 采集数据(API/爬虫/数据库等)
# 2. 生成图表(matplotlib/plotly等)
# 3. 返回图片完整路径
return str(image_path)
🎯 使用场景示例
| 页面 | 类型 | 内容 | 更新频率 |
|---|---|---|---|
| 1-3页 | static | 封面、目录、分析框架 | 固定不变 |
| 4页 | dynamic | GDP趋势图 | 每月更新 |
| 5页 | dynamic | CPI/PPI通胀图 | 每月更新 |
| 7页 | dynamic | 就业数据表 | 每月更新 |
| 10页 | dynamic | 进出口贸易 | 每月更新 |
| 13页 | dynamic | A股市场分析 | 每周更新 |
| 其他页 | static | 原理、方法论 | 固定不变 |
❓ 常见问题排查
Q1: 报错 FileNotFoundError: 静态PPT文件不存在: static_ppt/macro_analysis_template.pptx
运行 python create_sample_template.py 生成示例模板
Q2: 访问localhost:5000首页报错
检查Flask是否正常启动在5000端口,以及templates目录是否存在
Q3: 生成的PPT里动态页是空白
检查动态脚本是否报错,查看logs目录下日志排查