← 返回 Skills 市场
claw-presentation-creator
作者
weaglewang
· GitHub ↗
· v1.0.0
· MIT-0
465
总下载
0
收藏
0
当前安装
1
版本数
在 OpenClaw 中安装
/install claw-presentation-creator
功能描述
Create professional PowerPoint presentations with python-pptx. Supports slides, charts, tables, images, and templates.
使用说明 (SKILL.md)
PPTX Skill v2.0
Overview
Complete PowerPoint presentation creation and editing using python-pptx. Supports all common slide operations including text, images, charts, tables, and animations.
Installation & Dependencies
Required
pip install python-pptx pillow
Optional
# For advanced chart support
pip install numpy
# For HTML conversion (advanced)
npm install puppeteer dom-to-pptx
Quick Start
Create First Presentation
from pptx import Presentation
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[0])
slide.shapes.title.text = "Hello World"
prs.save('presentation.pptx')
print("✓ Presentation created!")
Add Content Slide
from pptx import Presentation
prs = Presentation()
# Title slide
slide = prs.slides.add_slide(prs.slide_layouts[0])
slide.shapes.title.text = "My Presentation"
slide.placeholders[1].text = "Subtitle here"
# Content slide
slide = prs.slides.add_slide(prs.slide_layouts[1])
slide.shapes.title.text = "Agenda"
slide.placeholders[1].text = "• Point 1\
• Point 2\
• Point 3"
prs.save('output.pptx')
Complete API Reference
Slide Layouts
from pptx import Presentation
prs = Presentation()
# Available layouts (indices may vary by template)
# 0 - Title Slide
slide = prs.slides.add_slide(prs.slide_layouts[0])
slide.shapes.title.text = "Title"
slide.placeholders[1].text = "Subtitle"
# 1 - Title and Content
slide = prs.slides.add_slide(prs.slide_layouts[1])
slide.shapes.title.text = "Heading"
slide.placeholders[1].text = "Content here"
# 2 - Section Header
slide = prs.slides.add_slide(prs.slide_layouts[2])
# 3 - Two Content
slide = prs.slides.add_slide(prs.slide_layouts[3])
# 4 - Comparison
slide = prs.slides.add_slide(prs.slide_layouts[4])
# 5 - Title Only
slide = prs.slides.add_slide(prs.slide_layouts[5])
# 6 - Blank
slide = prs.slides.add_slide(prs.slide_layouts[6])
Text Formatting
from pptx import Presentation
from pptx.util import Inches, Pt
from pptx.dml.color import RGBColor
from pptx.enum.text import PP_ALIGN
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[1])
# Title formatting
title = slide.shapes.title
title.text = "Formatted Title"
title.text_frame.paragraphs[0].font.name = 'Arial'
title.text_frame.paragraphs[0].font.size = Pt(36)
title.text_frame.paragraphs[0].font.bold = True
title.text_frame.paragraphs[0].font.color.rgb = RGBColor(0, 0, 0)
# Content formatting
content = slide.placeholders[1]
tf = content.text_frame
tf.text = "First paragraph"
# Add paragraph with formatting
p = tf.add_paragraph()
p.text = "Second paragraph"
p.level = 0 # Indentation level
p.alignment = PP_ALIGN.LEFT
# Run-level formatting (within paragraph)
run = p.add_run()
run.text = "Bold text"
run.font.bold = True
run.font.size = Pt(14)
run.font.name = 'Arial'
run.font.color.rgb = RGBColor(0, 112, 192) # Blue
run = p.add_run()
run.text = " and "
run = p.add_run()
run.text = "italic text"
run.font.italic = True
Adding Images
from pptx import Presentation
from pptx.util import Inches
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[5]) # Blank layout
# Add image
left = top = Inches(1)
slide.shapes.add_picture(
'image.jpg',
left,
top,
width=Inches(5),
height=Inches(3) # Optional, maintains aspect ratio if omitted
)
# Add image with caption
slide.shapes.add_picture('logo.png', Inches(1), Inches(5), width=Inches(2))
# Add textbox for caption
txBox = slide.shapes.add_textbox(Inches(3.2), Inches(5), Inches(3), Inches(1))
tf = txBox.text_frame
tf.text = "Image caption here"
prs.save('with-image.pptx')
Adding Tables
from pptx import Presentation
from pptx.util import Inches
from pptx.dml.color import RGBColor
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[5])
# Add table: 3 rows, 3 columns
rows = cols = 3
left = top = Inches(2)
width = Inches(6)
height = Inches(2)
table = slide.shapes.add_table(rows, cols, left, top, width, height).table
# Set column widths
table.columns[0].width = Inches(2)
table.columns[1].width = Inches(2)
table.columns[2].width = Inches(2)
# Fill data
table.cell(0, 0).text = 'Header 1'
table.cell(0, 1).text = 'Header 2'
table.cell(0, 2).text = 'Header 3'
table.cell(1, 0).text = 'Row 1'
table.cell(1, 1).text = 'Data 1'
table.cell(1, 2).text = 'Data 2'
table.cell(2, 0).text = 'Row 2'
table.cell(2, 1).text = 'Data 3'
table.cell(2, 2).text = 'Data 4'
# Format cells
cell = table.cell(0, 0)
cell.fill.solid()
cell.fill.fore_color.rgb = RGBColor(0, 112, 192) # Blue header
cell.text_frame.paragraphs[0].font.color.rgb = RGBColor(255, 255, 255)
cell.text_frame.paragraphs[0].font.bold = True
# Center align all cells
for row in table.rows:
for cell in row.cells:
cell.text_frame.paragraphs[0].alignment = PP_ALIGN.CENTER
prs.save('with-table.pptx')
Adding Charts
from pptx import Presentation
from pptx.chart.data import CategoryChartData
from pptx.enum.chart import XL_CHART_TYPE
from pptx.util import Inches
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[5])
# Prepare chart data
chart_data = CategoryChartData()
chart_data.categories = ['Q1', 'Q2', 'Q3', 'Q4']
chart_data.add_series('Revenue', (100000, 150000, 200000, 250000))
chart_data.add_series('Expenses', (80000, 100000, 120000, 140000))
# Add chart
x, y, cx, cy = Inches(1), Inches(1), Inches(8), Inches(5)
chart = slide.shapes.add_chart(
XL_CHART_TYPE.COLUMN_CLUSTERED, # Chart type
x, y, cx, cy,
chart_data
).chart
# Customize chart
chart.has_title = True
chart.chart_title.text_frame.text = 'Quarterly Financials'
chart.value_axis.has_major_gridlines = True
chart.category_axis.tick_labels.font.size = Pt(10)
prs.save('with-chart.pptx')
Chart Types
from pptx.enum.chart import XL_CHART_TYPE
# Available chart types
XL_CHART_TYPE.COLUMN_CLUSTERED # Clustered column
XL_CHART_TYPE.COLUMN_STACKED # Stacked column
XL_CHART_TYPE.BAR_CLUSTERED # Clustered bar
XL_CHART_TYPE.LINE # Line chart
XL_CHART_TYPE.PIE # Pie chart
XL_CHART_TYPE.PIE_EXPLODED # Exploded pie
XL_CHART_TYPE.AREA # Area chart
XL_CHART_TYPE.XY_SCATTER # Scatter plot
XL_CHART_TYPE.BUBBLE # Bubble chart
XL_CHART_TYPE.DOUGHNUT # Doughnut chart
XL_CHART_TYPE.RADAR # Radar chart
Adding Shapes
from pptx import Presentation
from pptx.util import Inches
from pptx.enum.shapes import MSO_SHAPE
from pptx.dml.color import RGBColor
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[5])
# Add rectangle
shape = slide.shapes.add_shape(
MSO_SHAPE.ROUNDED_RECTANGLE,
Inches(1), Inches(1), Inches(3), Inches(2)
)
shape.fill.solid()
shape.fill.fore_color.rgb = RGBColor(0, 112, 192)
shape.line.color.rgb = RGBColor(0, 0, 0)
# Add text to shape
tf = shape.text_frame
tf.text = "Click Shape"
tf.paragraphs[0].font.color.rgb = RGBColor(255, 255, 255)
tf.paragraphs[0].alignment = PP_ALIGN.CENTER
# Add arrow
arrow = slide.shapes.add_shape(
MSO_SHAPE.RIGHT_ARROW,
Inches(4.5), Inches(1.5), Inches(2), Inches(1)
)
# Add ellipse
ellipse = slide.shapes.add_shape(
MSO_SHAPE.OVAL,
Inches(1), Inches(4), Inches(2), Inches(2)
)
prs.save('with-shapes.pptx')
Using Templates
from pptx import Presentation
# Use existing template
prs = Presentation('template.pptx')
# Add slides with template layouts
slide = prs.slides.add_slide(prs.slide_layouts[1])
slide.shapes.title.text = "Using Template"
# Access slide master
slide_master = prs.slide_master
print(f"Template has {len(slide_master.slide_layouts)} layouts")
prs.save('customized.pptx')
Notes and Handouts
from pptx import Presentation
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[1])
slide.shapes.title.text = "Slide with Notes"
# Add speaker notes
notes_slide = slide.notes_slide
notes_slide.notes_text_frame.text = """
Speaker Notes:
- Key point 1
- Key point 2
- Remember to mention Q3 results
"""
prs.save('with-notes.pptx')
Complete Examples
Example 1: Business Presentation
from pptx import Presentation
from pptx.util import Inches, Pt
from pptx.dml.color import RGBColor
from pptx.enum.text import PP_ALIGN
def create_business_presentation(output_file):
prs = Presentation()
# Slide 1: Title
slide = prs.slides.add_slide(prs.slide_layouts[0])
slide.shapes.title.text = "Q4 Business Review"
slide.placeholders[1].text = "December 2024\
Presented by: John Doe"
# Slide 2: Agenda
slide = prs.slides.add_slide(prs.slide_layouts[1])
slide.shapes.title.text = "Agenda"
tf = slide.placeholders[1].text_frame
tf.text = "Business Overview"
for item in ["Financial Performance", "Key Achievements", "Challenges", "Next Steps"]:
p = tf.add_paragraph()
p.text = item
p.level = 0
# Slide 3: Financial Table
slide = prs.slides.add_slide(prs.slide_layouts[5])
title = slide.shapes.add_textbox(Inches(0.5), Inches(0.3), Inches(9), Inches(1))
title.text_frame.text = "Financial Summary"
title.text_frame.paragraphs[0].font.size = Pt(24)
title.text_frame.paragraphs[0].font.bold = True
# Add table
rows, cols = 5, 4
left, top, width, height = Inches(0.5), Inches(1.5), Inches(9), Inches(4)
table = slide.shapes.add_table(rows, cols, left, top, width, height).table
# Headers
headers = ['Metric', 'Q1', 'Q2', 'Q3']
for i, header in enumerate(headers):
cell = table.cell(0, i)
cell.text = header
cell.fill.solid()
cell.fill.fore_color.rgb = RGBColor(0, 112, 192)
cell.text_frame.paragraphs[0].font.color.rgb = RGBColor(255, 255, 255)
cell.text_frame.paragraphs[0].font.bold = True
# Data
data = [
['Revenue', '$1.2M', '$1.5M', '$1.8M'],
['Expenses', '$0.8M', '$0.9M', '$1.0M'],
['Profit', '$0.4M', '$0.6M', '$0.8M'],
['Margin', '33%', '40%', '44%']
]
for row_idx, row_data in enumerate(data, 1):
for col_idx, value in enumerate(row_data):
table.cell(row_idx, col_idx).text = value
# Slide 4: Closing
slide = prs.slides.add_slide(prs.slide_layouts[1])
slide.shapes.title.text = "Thank You"
slide.placeholders[1].text = "Questions?\
\
[email protected]"
prs.save(output_file)
print(f"✓ Presentation created: {output_file}")
# Usage
create_business_presentation('business-review.pptx')
Example 2: Photo Gallery
from pptx import Presentation
from pptx.util import Inches
import os
def create_photo_gallery(image_folder, output_file):
"""Create a photo gallery presentation"""
prs = Presentation()
# Title slide
slide = prs.slides.add_slide(prs.slide_layouts[0])
slide.shapes.title.text = "Photo Gallery"
slide.placeholders[1].text = f"Images from {image_folder}"
# Get images
images = [f for f in os.listdir(image_folder) if f.endswith(('.jpg', '.png', '.jpeg'))]
# Add images (2 per slide)
for i in range(0, len(images), 2):
slide = prs.slides.add_slide(prs.slide_layouts[5])
# First image
if i \x3C len(images):
img_path = os.path.join(image_folder, images[i])
slide.shapes.add_picture(img_path, Inches(0.5), Inches(1.5), width=Inches(4.5))
# Caption
txBox = slide.shapes.add_textbox(Inches(0.5), Inches(5.5), Inches(4.5), Inches(1))
tf = txBox.text_frame
tf.text = images[i]
tf.paragraphs[0].alignment = PP_ALIGN.CENTER
# Second image
if i + 1 \x3C len(images):
img_path = os.path.join(image_folder, images[i + 1])
slide.shapes.add_picture(img_path, Inches(5), Inches(1.5), width=Inches(4.5))
# Caption
txBox = slide.shapes.add_textbox(Inches(5), Inches(5.5), Inches(4.5), Inches(1))
tf = txBox.text_frame
tf.text = images[i + 1]
tf.paragraphs[0].alignment = PP_ALIGN.CENTER
prs.save(output_file)
print(f"✓ Gallery created with {len(images)} images: {output_file}")
# Usage
# create_photo_gallery('./photos', 'gallery.pptx')
Example 3: Invoice Presentation
from pptx import Presentation
from pptx.util import Inches, Pt
from pptx.dml.color import RGBColor
def create_invoice_pptx(invoice_data, output_file):
"""Create invoice as PowerPoint slide"""
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[5])
# Title
title = slide.shapes.add_textbox(Inches(0.5), Inches(0.3), Inches(9), Inches(1))
title.text_frame.text = "INVOICE"
title.text_frame.paragraphs[0].font.size = Pt(36)
title.text_frame.paragraphs[0].font.bold = True
title.text_frame.paragraphs[0].alignment = PP_ALIGN.CENTER
# Invoice details
details = slide.shapes.add_textbox(Inches(0.5), Inches(1.5), Inches(4), Inches(2))
tf = details.text_frame
tf.text = f"Invoice #: {invoice_data['number']}\
"
tf.text += f"Date: {invoice_data['date']}\
"
tf.text += f"Due: {invoice_data['due_date']}"
# Client info
client = slide.shapes.add_textbox(Inches(5.5), Inches(1.5), Inches(4), Inches(2))
tf = client.text_frame
tf.text = f"Bill To:\
{invoice_data['client_name']}\
{invoice_data['client_address']}"
# Items table
rows = len(invoice_data['items']) + 2
table = slide.shapes.add_table(rows, 4, Inches(0.5), Inches(4), Inches(9), Inches(3)).table
# Headers
headers = ['Description', 'Qty', 'Rate', 'Amount']
for i, header in enumerate(headers):
cell = table.cell(0, i)
cell.text = header
cell.fill.solid()
cell.fill.fore_color.rgb = RGBColor(0, 112, 192)
cell.text_frame.paragraphs[0].font.color.rgb = RGBColor(255, 255, 255)
cell.text_frame.paragraphs[0].font.bold = True
# Items
total = 0
for row_idx, item in enumerate(invoice_data['items'], 1):
amount = item['qty'] * item['rate']
total += amount
table.cell(row_idx, 0).text = item['description']
table.cell(row_idx, 1).text = str(item['qty'])
table.cell(row_idx, 2).text = f"${item['rate']:.2f}"
table.cell(row_idx, 3).text = f"${amount:.2f}"
# Total row
table.cell(rows-1, 2).text = "Total:"
table.cell(rows-1, 2).text_frame.paragraphs[0].font.bold = True
table.cell(rows-1, 3).text = f"${total:.2f}"
table.cell(rows-1, 3).text_frame.paragraphs[0].font.bold = True
prs.save(output_file)
print(f"✓ Invoice created: {output_file}")
# Usage
invoice = {
'number': 'INV-2024-001',
'date': '2024-01-15',
'due_date': '2024-02-15',
'client_name': 'ABC Corporation',
'client_address': '123 Business St\
City, State 12345',
'items': [
{'description': 'Web Development', 'qty': 40, 'rate': 100},
{'description': 'Design', 'qty': 20, 'rate': 80},
{'description': 'Consulting', 'qty': 10, 'rate': 150}
]
}
create_invoice_pptx(invoice, 'invoice.pptx')
Error Handling
Common Errors
Error: "Placeholder not found"
# Solution: Check layout has the placeholder
slide = prs.slides.add_slide(prs.slide_layouts[0])
if len(slide.placeholders) > 1:
slide.placeholders[1].text = "Subtitle"
Error: "Image not found"
# Solution: Check file exists before adding
import os
if os.path.exists('image.jpg'):
slide.shapes.add_picture('image.jpg', Inches(1), Inches(1))
else:
print("Image file not found!")
Error: "Chart data error"
# Solution: Ensure data categories and series match
chart_data = CategoryChartData()
chart_data.categories = ['Q1', 'Q2', 'Q3'] # Must match series length
chart_data.add_series('Revenue', (100, 150, 200))
Best Practices
1. Use Master Slides for Consistency
# Edit slide master for consistent branding
slide_master = prs.slide_master
title_layout = slide_master.slide_layouts[0]
2. Keep File Size Manageable
# Compress images before adding
from PIL import Image
img = Image.open('large.jpg')
img.thumbnail((1920, 1080))
img.save('compressed.jpg', quality=85)
3. Use Standard Fonts
# Use fonts available on most systems
title.text_frame.paragraphs[0].font.name = 'Arial' # Safe choice
4. Limit Animations
# python-pptx has limited animation support
# Create simple, clean slides instead
Testing Your Setup
# test-pptx.py
from pptx import Presentation
from pptx.util import Inches
import os
print("Testing PPTX setup...")
# Test 1: Create basic presentation
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[0])
slide.shapes.title.text = "Test Presentation"
prs.save('test-output.pptx')
assert os.path.exists('test-output.pptx')
print("✓ Basic creation test passed")
# Test 2: Add content
slide = prs.slides.add_slide(prs.slide_layouts[1])
slide.shapes.title.text = "Content Slide"
slide.placeholders[1].text = "Test content"
prs.save('test-output.pptx')
print("✓ Content addition test passed")
# Test 3: Load and verify
prs = Presentation('test-output.pptx')
assert len(prs.slides) == 2
print("✓ Load and verify test passed")
# Cleanup
os.remove('test-output.pptx')
print("✓ All tests passed!")
Run test:
python test-pptx.py
License
MIT License - See LICENSE file for details.
安全使用建议
This skill appears coherent and focused on creating PPTX files. Before installing or letting an agent run the installation commands: 1) Prefer running pip/npm commands yourself inside a Python virtual environment (venv) or container to avoid polluting the system environment. 2) Review and install only from trusted package registries (PyPI/npm); note that npm puppeteer typically downloads a large Chromium binary. 3) Installing packages can run code at install-time—avoid installing as root. 4) The skill does not request secrets, but if you allow an agent to execute commands autonomously, it may run the pip/npm commands shown here; consider disabling autonomous execution or reviewing commands first. 5) If you need to be extra cautious, copy the example snippets and run them locally rather than granting the agent permission to execute installs or create files on your behalf.
功能分析
Type: OpenClaw Skill
Name: claw-presentation-creator
Version: 1.0.0
The skill bundle provides comprehensive documentation and Python code examples for creating PowerPoint presentations using the standard 'python-pptx' library. All instructions and code snippets in SKILL.md are strictly aligned with the stated purpose of content creation, and no indicators of malicious intent, data exfiltration, or harmful prompt injection were found.
能力评估
Purpose & Capability
The name and description (PowerPoint creation with python-pptx) match the SKILL.md content. Required packages (python-pptx, pillow; optional numpy, puppeteer/dom-to-pptx) are relevant to the documented functionality. Nothing in the spec requests unrelated cloud credentials, system services, or unusual binaries.
Instruction Scope
SKILL.md contains concrete python examples that create and save .pptx files and explains package installation. It does not instruct the agent to read arbitrary system files, harvest environment variables, contact external endpoints other than package registries, or transmit user data. File operations shown are limited to creating/saving presentations and reading images/templates the user provides.
Install Mechanism
This is an instruction-only skill with no automated install spec; it tells users/agents to run pip/npm installs. Those are standard but will pull code from PyPI/npm (and puppeteer typically downloads a Chromium binary). There is no embedded or obscure download URL in the skill itself.
Credentials
The skill requests no environment variables, credentials, or config paths. The declared requirements are proportional to the task (Python and optional Node packages).
Persistence & Privilege
always is false and the skill is user-invocable. The skill does not request permanent platform presence or attempt to modify other skills or system-wide agent settings.
如何使用
- 确保已安装 OpenClaw(本地或 Docker 部署)
- 在对话框中输入安装命令:
/install claw-presentation-creator - 安装完成后,直接呼叫该 Skill 的名称或使用
/claw-presentation-creator触发 - 根据 Skill 的参数说明提供必要输入,即可获得结构化输出
版本历史
v1.0.0
claw-presentation-creator 2.0.0 is a major update with expanded PowerPoint creation features.
- Now supports creating and editing complete presentations, including text, images, charts, tables, and custom templates.
- Detailed code examples provided for common slide operations and advanced formatting.
- Chart, table, and image insertion with formatting and customization now covered step-by-step.
- Added guidance for advanced usage, optional dependencies, and template support.
- Significantly expanded documentation and API reference for clarity and ease of use.
元数据
常见问题
claw-presentation-creator 是什么?
Create professional PowerPoint presentations with python-pptx. Supports slides, charts, tables, images, and templates. 它是一个面向 Claude Code / OpenClaw 的 AI Agent Skill 插件,目前累计下载 465 次。
如何安装 claw-presentation-creator?
在 OpenClaw 或 Claude Code 对话框中运行命令「/install claw-presentation-creator」即可一键安装,无需额外配置。
claw-presentation-creator 是免费的吗?
是的,claw-presentation-creator 完全免费,采用 MIT-0 许可证,可自由下载、安装和使用。
claw-presentation-creator 支持哪些平台?
claw-presentation-creator 跨平台运行,可在任意部署了 OpenClaw / Claude Code 的环境中使用(cross-platform)。
谁开发了 claw-presentation-creator?
由 weaglewang(@weaglewang)开发并维护,当前版本 v1.0.0。
推荐 Skills