pptx

SKILL.md

PPT演示文稿处理专家 Real Skill

一句话说明

从 HTML 自动生成精美 PPT,支持演示文稿编辑、批注管理和内容提取。

Presentation Creation & Editing - Creating presentations from HTML, editing content, managing comments, extracting text.


使用场景

适用

  • 从数据/HTML 自动生成标准化 PPT 报告
  • 创建精美的演示文稿(销售、培训、汇报)
  • 提取 PPT 文本、批注、演讲者备注
  • 修改幻灯片内容、布局、主题
  • 批量生成多个演示文稿

不适用

  • 复杂动画制作(用专业软件 / use professional software)
  • 实时协同编辑(用 Google Slides / use Google Slides for real-time collaboration)

核心流程

用户需求 → 内容分析 → 配色选择 → 工具选择 → 生成 PPT → 验证输出
User request → Content analysis → Color palette → Tool selection → Generate PPT → Validate

任务类型判断 (Task Classification)

Creating Presentations (创建演示文稿)

  • HTML to PPT Workflow (推荐 / RECOMMENDED)

    • Write HTML slides with styling
    • Convert using html2pptx library
    • Accurate positioning and formatting
    • Web-safe fonts only (Arial, Helvetica, Georgia, etc.)
  • Python-PPTX Workflow

    • Programmatic slide creation
    • Batch generation from data
    • Template-based automation

Reading & Analysis (读取与分析)

  • Text extraction → markitdown (convert to markdown)
  • Comments & Notes → Unpack OOXML and read XML
  • Design analysis → Extract theme, colors, fonts from XML

Editing Existing (编辑已有文稿)

  • Simple edits → python-pptx library
  • Complex edits → Unpack OOXML, modify XML, repack

任务完成标准

必须满足(缺一不可):

  • PPT 可正常打开并播放
  • 幻灯片内容清晰可读
  • 配色协调,视觉层次分明
  • 布局合理,文字不拥挤

质量评级

  • ⭐⭐⭐⭐⭐ 优秀 - 设计精美 + 内容完整 + 自动化生成
  • ⭐⭐⭐ 及格 - 内容正确 + PPT 可用 + 格式规范
  • ⭐ 失败 - PPT 损坏或内容错误

参考资料(供 AI 使用)

类型 路径 说明
核心文档 docs/00-SKILL-完整制作指南.md Complete PPT creation guide (~500 lines)
OOXML库 ooxml/ Low-level XML operations
工具脚本 scripts/unpack.py Unpack PPTX files
工具脚本 scripts/pack.py Pack PPTX files

关键原则(AI 必读 / Critical Principles)

1. Design First - Content-Informed Approach (设计先行)

CRITICAL: Before creating any presentation, analyze the content:

  • Consider subject matter: What is this about? What tone/industry/mood?
  • Check branding: If company mentioned, consider brand colors
  • Match palette to content: Select colors reflecting the subject
  • State your approach: Explain design choices BEFORE writing code

2. Web-Safe Fonts Only (仅使用 Web 安全字体)

Allowed fonts: Arial, Helvetica, Times New Roman, Georgia, Courier New, Verdana, Tahoma, Trebuchet MS, Impact

  • No custom fonts: They won't render correctly
  • Font pairing: Use max 2-3 fonts per presentation

3. Visual Hierarchy (视觉层次)

  • Extreme size contrast: 72pt headlines vs 11pt body text
  • Weight variation: Bold headers, normal body, light captions
  • Color emphasis: Use accent color for key information
  • Clear structure: Title → Main content → Supporting details

4. Chart & Table Layout Rules (图表布局规则)

PREFERRED - Two-column layout:

  • Header spanning full width
  • Text/bullets in one column (40%) + Chart/table in other (60%)
  • Better balance and readability

Alternative - Full-slide layout:

  • Chart/table takes entire slide for maximum impact

NEVER vertically stack:

  • ❌ Do NOT place charts/tables below text in single column
  • ❌ Causes poor readability and layout issues

5. Color Palette Selection (18种配色方案)

Think beyond defaults: What colors genuinely match this topic? Consider multiple angles: Topic, industry, mood, energy, audience, brand Be adventurous: Healthcare doesn't have to be green, finance doesn't have to be navy


18种精选配色方案 (Color Palettes)

Business & Professional (商业/专业)

  1. Classic Blue: Navy (#1C2833), Slate (#2E4053), Silver (#AAB7B8), Off-white (#F4F6F6)
  2. Black & Gold: Gold (#BF9A4A), Black (#000000), Cream (#F4F6F6)
  3. Charcoal & Red: Charcoal (#292929), Red (#E33737), Light Gray (#CCCBCB)

Creative & Vibrant (创意/活力)

  1. Teal & Coral: Teal (#5EA8A7), Deep Teal (#277884), Coral (#FE4447), White (#FFFFFF)
  2. Retro Rainbow: Purple (#722880), Pink (#D72D51), Orange (#EB5C18), Amber (#F08800), Gold (#DEB600)
  3. Vibrant Orange: Orange (#F96D00), Light Gray (#F2F2F2), Charcoal (#222831)
  4. Bold Red: Red (#C0392B), Bright Red (#E74C3C), Orange (#F39C12), Yellow (#F1C40F), Green (#2ECC71)

Natural & Warm (自然/温暖)

  1. Sage & Terracotta: Sage (#87A96B), Terracotta (#E07A5F), Cream (#F4F1DE), Charcoal (#2C2C2C)
  2. Forest Green: Black (#191A19), Green (#4E9F3D), Dark Green (#1E5128), White (#FFFFFF)
  3. Vintage Earthy: Mustard (#E3B448), Sage (#CBD18F), Forest Green (#3A6B35), Cream (#F4F1DE)
  4. Cream & Forest: Cream (#FFE1C7), Forest Green (#40695B), White (#FCFCFC)

Elegant & Soft (优雅/柔和)

  1. Warm Blush: Mauve (#A49393), Blush (#EED6D3), Rose (#E8B4B8), Cream (#FAF7F2)
  2. Coastal Rose: Old Rose (#AD7670), Beaver (#B49886), Eggshell (#F3ECDC), Ash Gray (#BFD5BE)
  3. Pink & Purple: Pink (#F8275B), Coral (#FF574A), Rose (#FF737D), Purple (#3D2F68)

Luxury & Bold (奢华/大胆)

  1. Burgundy Luxury: Burgundy (#5D1D2E), Crimson (#951233), Rust (#C15937), Gold (#997929)
  2. Deep Purple & Emerald: Purple (#B165FB), Dark Blue (#181B24), Emerald (#40695B), White (#FFFFFF)

Fresh & Modern (清新/现代)

  1. Lime & Plum: Lime (#C5DE82), Plum (#7C3A5F), Coral (#FD8C6E), Blue-Gray (#98ACB5)
  2. Orange & Turquoise: Light Orange (#FC993E), Grayish Turquoise (#667C6F), White (#FCFCFC)

快速命令参考 (Quick Commands)

Text Extraction (文本提取)

# Convert PPTX to markdown
python -m markitdown presentation.pptx

Create Simple Presentation (创建简单演示文稿)

from pptx import Presentation

prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[0])  # Title slide
title = slide.shapes.title
subtitle = slide.placeholders[1]

title.text = "Hello World!"
subtitle.text = "My First Presentation"

prs.save("output.pptx")

Unpack PPTX for Analysis (解压分析)

# Unpack PPTX to access raw XML
python ooxml/scripts/unpack.py presentation.pptx output_dir

# Key files to examine:
# ppt/presentation.xml - Main metadata
# ppt/slides/slide1.xml - Individual slide contents
# ppt/theme/theme1.xml - Theme colors and fonts
# ppt/comments/ - Comments
# ppt/notesSlides/ - Speaker notes

Repack After Editing (编辑后打包)

# Pack modified XML back to PPTX
python ooxml/scripts/pack.py output_dir new_presentation.pptx

HTML to PPT Workflow (HTML 转 PPT)

# Step 1: Write HTML slides
html_content = """
<!DOCTYPE html>
<html>
<head>
    <style>
        .slide { width: 960px; height: 720px; padding: 40px; }
        h1 { font-family: Arial; font-size: 48px; color: #1C2833; }
        p { font-family: Arial; font-size: 24px; color: #2E4053; }
    </style>
</head>
<body>
    <div class="slide">
        <h1>Welcome</h1>
        <p>This is my presentation</p>
    </div>
</body>
</html>
"""

# Step 2: Convert to PPTX
from html2pptx import html2pptx
with open("slides.html", "w") as f:
    f.write(html_content)
html2pptx("slides.html", "output.pptx")

依赖安装 (Dependencies Installation)

Python Dependencies

pip install -r requirements.txt
# Includes: python-pptx, html2pptx, markitdown

常见场景示例 (Common Scenarios)

Scenario 1: Create Professional Title Slide (创建专业标题页)

from pptx import Presentation
from pptx.util import Inches, Pt
from pptx.dml.color import RGBColor

prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[6])  # Blank layout

# Add title
left = Inches(1)
top = Inches(2.5)
width = Inches(8)
height = Inches(1.5)
title_box = slide.shapes.add_textbox(left, top, width, height)
title_frame = title_box.text_frame
title_frame.text = "2024 Sales Report"

# Format title
title_para = title_frame.paragraphs[0]
title_para.font.size = Pt(72)
title_para.font.bold = True
title_para.font.color.rgb = RGBColor(28, 40, 51)  # Navy

# Add subtitle
subtitle_box = slide.shapes.add_textbox(left, Inches(4), width, Inches(0.5))
subtitle_frame = subtitle_box.text_frame
subtitle_frame.text = "Q4 Performance Review"
subtitle_para = subtitle_frame.paragraphs[0]
subtitle_para.font.size = Pt(24)
subtitle_para.font.color.rgb = RGBColor(46, 64, 83)  # Slate

prs.save("title_slide.pptx")

Scenario 2: Extract All Speaker Notes (提取所有演讲者备注)

# Step 1: Unpack PPTX
python ooxml/scripts/unpack.py presentation.pptx unpacked/

# Step 2: Extract notes using grep
cd unpacked/ppt/notesSlides/
grep -r "a:t>" . | sed 's/<[^>]*>//g' > ../../all_notes.txt

Scenario 3: Batch Generate Slides from Data (批量生成幻灯片)

from pptx import Presentation
from pptx.util import Inches, Pt

data = [
    {"name": "Product A", "sales": 1200, "growth": "15%"},
    {"name": "Product B", "sales": 980, "growth": "8%"},
    {"name": "Product C", "sales": 1450, "growth": "22%"}
]

prs = Presentation()

for item in data:
    slide = prs.slides.add_slide(prs.slide_layouts[1])  # Title and content
    title = slide.shapes.title
    title.text = item["name"]
    
    body = slide.placeholders[1]
    tf = body.text_frame
    tf.text = f"Sales: ${item['sales']}M"
    
    p = tf.add_paragraph()
    p.text = f"Growth: {item['growth']}"
    p.level = 1

prs.save("batch_report.pptx")
Weekly Installs
18
GitHub Stars
87
First Seen
1 day ago
Installed on
opencode18
gemini-cli18
github-copilot18
codex18
amp18
cline18