Skip to main content

Real-time PowerPoint control via COM automation — an MCP server with 148 tools for AI agents

Project description

PowerPoint MCP

日本語版はこちら

Python License Platform Downloads

Real-time PowerPoint control through COM automation —
an MCP server with 152 tools for AI agents and developers.


An MCP (Model Context Protocol) server that gives AI agents full control over a live Microsoft PowerPoint instance via COM automation. Unlike file-based libraries like python-pptx, this server interacts directly with a running PowerPoint application.

✨ Key Features

  • Real-time control — Directly manipulates a running PowerPoint instance; changes appear instantly on screen
  • 152 tools across 26 categories — Slides, shapes, text, tables, charts, animations, SmartArt, media, freeform paths, and more
  • Safe for AI agentsppt_activate_presentation locks all tools to a specific file, preventing accidental edits to the wrong presentation
  • Google Material Symbols icons — Search 2,500+ icons by keyword and insert as SVG with theme colors
  • Theme color awareness — Use accent1, accent2, etc. instead of hardcoded RGB values

📋 Requirements

  • Windows 11
  • Microsoft PowerPoint
  • uv

🚀 Getting Started

Standard config — works in Claude Desktop, Cursor, .mcp.json, and most other MCP clients:

{
  "mcpServers": {
    "powerpoint": {
      "command": "uvx",
      "args": ["ppt-mcp"]
    }
  }
}

Claude Code

User-scoped (available in all projects)

claude mcp add powerpoint uvx ppt-mcp

Project-scoped (stored in .mcp.json, shared with your team)

claude mcp add --scope project powerpoint uvx ppt-mcp

Cursor

Install in Cursor

Or add manually to ~/.cursor/mcp.json using the standard config above.

Claude Desktop

Edit %APPDATA%\Claude\claude_desktop_config.json using the standard config above.

Codex

Edit ~/.codex/config.toml:

[mcp_servers.ppt-mcp]
command = "uvx"
args = ["ppt-mcp"]

Or use the standard JSON config above in .codex/config.json.

VS Code

code --add-mcp '{"name":"powerpoint","command":"uvx","args":["ppt-mcp"]}'

From source

git clone https://github.com/ykuwai/ppt-mcp.git
cd ppt-mcp
uv sync
{
  "mcpServers": {
    "powerpoint": {
      "command": "uv",
      "args": [
        "--directory",
        "C:\\path\\to\\ppt-mcp",
        "run",
        "mcp",
        "run",
        "src/server.py"
      ]
    }
  }
}

🛠️ Tool Categories

Category Tools Description
App 5 Connect to PowerPoint, app info, active window, window state, list presentations
Presentation 8 Create (with templates), open, save, close, info, activate target, list templates
Slides 9 Add, delete, duplicate, move, list, info, notes, navigation
Shapes 10 Add shapes/textboxes/pictures/lines, list, info, update, delete, z-order
Text 10 Set/get text, format text ranges, paragraph format, bullets, find/replace, textframe, extract all text as Markdown, typography check
Placeholders 6 List, get, set placeholder content
Formatting 3 Fill, line, shadow
Tables 13 Add tables, get/set cells, batch set data, merge/split cells, add/delete rows/columns, styles, layout, borders
Export 3 PDF, images, slide preview
Slideshow 6 Start, stop, next, previous, go to slide, status
Charts 6 Add charts, set/get data, format, series, change type
Animation 6 Transitions, add/list/update/remove/clear animations (entrance, exit, emphasis, motion path, interactive sequences)
Themes 3 Apply themes, get theme colors, headers/footers
Groups 3 Group, ungroup, get group items
Connectors 2 Add, format
Hyperlinks 3 Add, get, remove
Sections 3 Add, list, manage
Properties 2 Set/get presentation metadata
Media 3 Video, audio, media settings
SmartArt 3 Add, modify, list layouts
Edit Operations 6 Undo, redo, copy shapes/formatting between slides
Layout 7 Align, distribute, slide size, background, flip, merge shapes
Effects 3 Glow, reflection, soft edge
Comments 3 Add, list, delete
Advanced 19 Tags, fonts (set defaults + bulk replace), crop, picture format, shape export, visibility, selection, view, animation copy, picture from URL, SVG icons, icon search, aspect ratio lock, batch apply, default shape style
Freeform 7 Build freeform paths, get/set node positions, insert/delete nodes, node editing type, segment type
152

💡 Example Prompts

Just describe what you want in plain language — no code required.


Simple — topic only

"Create a 3-slide intro deck for a productivity app called Flowly."

View slides

With style direction — topic + visual style

"Make a 4-slide presentation on the benefits of async work. Dark navy style, add icons for each benefit."

View slides

Detailed — topic + design intent + slide structure

"Build a 5-slide pitch for an AI note-taking app called NoteAI. White background, teal accent. Slides: title, problem, solution, features with icons, closing."

View slides

Design keywords that elevate results:

Aspect Keywords / Phrases What it does
Icons add icons · icon for each point · use icons throughout Searches Google Material Symbols and places crisp SVG icons automatically
Color scheme dark navy · white background · monochrome · light gray Sets the overall color palette and mood
Accent color teal accent · blue accent · brand color #2563EB Applies a specific highlight color to headings, icons, and shapes
Style tone modern minimal · bold and vibrant · clean and professional · playful Signals the overall visual personality
Deck type pitch deck · investor presentation · workshop slides · status report Guides layout and content density toward the intended purpose
Slide structure Slides: title, problem, solution, features, CTA · 4 slides Defines the narrative arc and slide count up front
Layout card layout · two-column · centered · full-bleed background Shapes how content is arranged on each slide
Text density minimal text · one message per slide · bullet points Controls how much text appears and how it's formatted
Backgrounds gradient background · solid dark background · soft light background Specifies the background treatment across slides
Emphasis highlight key numbers · bold headings · accent bar on each slide Draws attention to the most important information

🔍 Features in Detail

🎯 Presentation Targeting

ppt_activate_presentation sets a session-level target so every subsequent tool call operates on that specific file — regardless of which window is active in PowerPoint. Switch targets anytime by calling it again.

ppt_activate_presentation(presentation_name="report.pptx")
# All tools now operate on report.pptx
ppt_activate_presentation(presentation_name="demo.pptx")
# Switched — all tools now operate on demo.pptx

📁 Template Support

Auto-detects your personal PowerPoint templates folder (registry, OneDrive, or default paths). Use ppt_list_templates to discover available templates, then ppt_create_presentation(template_path=...) to create a new presentation from any template.

🎨 Google Material Symbols Icons

Search 2,500+ Google Material Symbols icons with ppt_search_icons(query="...") and insert them as SVG with ppt_add_svg_icon:

  • 3 styles: outlined, rounded, sharp
  • Filled variants: set filled=True
  • Theme colors: color="accent1" uses the presentation's accent color
  • Auto-fit: preserves aspect ratio within the specified area

⚡ Real-Time Navigation

Every write operation automatically navigates PowerPoint to the target slide. You see changes happening in real-time — no need to manually switch slides.

✍️ Text Formatting

  • \n — Paragraph break (Enter). Each paragraph gets its own bullet/indent level.
  • \v — Line break (Shift+Enter). Stays in the same paragraph, preserving formatting.
  • Per-character formatting with ppt_format_text_range
  • Auto-fit control: shrink text to fit, resize shape, or overflow

⚙️ Advanced Configuration

Handling PowerPoint Modal Dialogs

When PowerPoint has a modal dialog open (e.g., SmartArt layout picker, Save dialog, Insert dialog), COM calls return RPC_E_CALL_REJECTED. The MCP server automatically retries for up to 15 seconds (5 retries × 3 s), so the server stays connected and responsive even when a dialog is blocking PowerPoint.

Auto-dismiss (opt-in): By default, the server waits for you to close the dialog manually. To have the server automatically send ESC on the first retry — dismissing the dialog without user interaction — set PPT_AUTO_DISMISS_DIALOG=true:

{
  "mcpServers": {
    "powerpoint": {
      "command": "uvx",
      "args": ["ppt-mcp"],
      "env": {
        "PPT_AUTO_DISMISS_DIALOG": "true"
      }
    }
  }
}

ESC cancels without committing, so there are no destructive side effects. This is particularly useful in automated workflows where no human is present to close dialogs.

📄 License

MIT

🙏 Credits

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ppt_mcp-1.0.0.tar.gz (3.5 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ppt_mcp-1.0.0-py3-none-any.whl (172.2 kB view details)

Uploaded Python 3

File details

Details for the file ppt_mcp-1.0.0.tar.gz.

File metadata

  • Download URL: ppt_mcp-1.0.0.tar.gz
  • Upload date:
  • Size: 3.5 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ppt_mcp-1.0.0.tar.gz
Algorithm Hash digest
SHA256 aef762b98dd22b38ef12edc15097633267d781344e997fa38a953cc9509e399d
MD5 47346986edc0163df21728e3a841d2ba
BLAKE2b-256 149c18e03ee684373feee6984147f0787b1fc1d1f095e80f95979d9f58e77615

See more details on using hashes here.

Provenance

The following attestation bundles were made for ppt_mcp-1.0.0.tar.gz:

Publisher: publish.yml on ykuwai/ppt-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ppt_mcp-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: ppt_mcp-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 172.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ppt_mcp-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7b9a3103769c4eddd1bd88e62086db3b9b407b1f08a2f797e041421cf36bbc78
MD5 1fb86ec44a24bd02bcd64ef5c0eb6417
BLAKE2b-256 122ba8f4604d7cc42d83c877153faba284c2e76e93a0ed7cc4c4daaf71a50c20

See more details on using hashes here.

Provenance

The following attestation bundles were made for ppt_mcp-1.0.0-py3-none-any.whl:

Publisher: publish.yml on ykuwai/ppt-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page