Conversion HTML vers PowerPoint (PPTX)

VérifiéPrudence

Convertit des diapositives HTML en fichiers PowerPoint (PPTX). Permet également de générer des miniatures et de modifier des présentations existantes. Utilisez pour créer ou modifier des présentations PowerPoint à partir de contenu HTML.

Spar Skills Guide Bot
ProductiviteIntermédiaire
6002/06/2026
Claude Code
#pptx#presentation#slides#html-conversion#powerpoint

Recommandé pour

Notre avis

Convertit des diapositives HTML en fichiers PowerPoint (PPTX) et permet d'éditer des présentations existantes ou de générer des vignettes.

Points forts

  • Conversion directe de HTML en PPTX avec conservation de la mise en page 16:9.
  • Prise en charge des graphiques, formes et images dans les diapositives.
  • Génération de vignettes pour un aperçu visuel rapide.
  • Outils de validation et de manipulation du format OOXML pour les utilisateurs avancés.

Limites

  • Nécessite une demande explicite et une validation manuelle des diapositives avant conversion.
  • Les codes couleur doivent être fournis sans '#' sous peine de corruption du fichier.
  • La conversion ne gère pas les animations complexes ou les mises en page non standard.
Quand l'utiliser

Utilisez cette compétence lorsque vous devez générer automatiquement une présentation PowerPoint à partir de diapositives HTML structurées.

Quand l'éviter

Évitez de l'utiliser si vous avez besoin d'animations avancées, de transitions personnalisées ou d'un contrôle pixel‑parfait sur le design.

Analyse de sécurité

Prudence
Score qualité90/100

The skill runs Node.js and Python scripts to convert HTML to PPTX, which is a legitimate use case but involves powerful tools that could be exploited if the input HTML is malicious. No exfiltration or destruction commands are present, but caution is warranted.

Points d'attention
  • Skill executes external scripts (html2pptx.js, thumbnail.py, pack.py, validate.py) that could process user-provided HTML, potentially leading to code execution or SSRF if the HTML contains malicious content.
  • Uses Playwright browser rendering which may expose system resources.

Exemples

Basic HTML to PPTX conversion
Convert the HTML slides in the 'slides' folder to a PowerPoint presentation named 'presentation.pptx'.
Thumbnail generation
Generate thumbnail images for my 'presentation.pptx' file with 4 columns and outline placeholders.
Edit existing PPTX
Unpack the existing 'presentation.pptx' into a directory, add a new slide with a bar chart showing sales data, then repack it.

name: pptx-skill description: Convert HTML slides to PowerPoint (PPTX) files. Use when PPTX generation, editing, or thumbnail creation is needed.

PPTX Skill - PowerPoint Conversion

Converts HTML slides into PowerPoint presentation files.

Feature Overview

1. New Presentation (HTML -> PPTX)

Convert HTML slide files to PowerPoint

2. Edit Existing Presentation

Modify contents of a PPTX file

3. Thumbnail Generation

Generate preview images of a presentation

Prerequisites (Stage 3)

This skill is Stage 3. It executes only when ALL of the following conditions are met:

  1. Explicit user request required: Only run when the user explicitly requests PPTX conversion ("convert to PPTX", "make a PowerPoint", etc.).
  2. HTML slides reviewed: All HTML slides must have been reviewed and approved by the user in viewer.html.
  3. No automatic execution: Do not automatically start PPTX conversion just because slide generation is complete.

If prerequisites are not met, guide the user to review slides in <slides-dir>/viewer.html first (default: slides/viewer.html).


Core Workflow

HTML -> PPTX Conversion

  1. Prepare HTML slides

    • Verify HTML files exist in selected --slides-dir (default: slides/)
    • Validate each file is 720pt x 405pt (16:9) specification
  2. Run html2pptx.js

    slides-grab convert --slides-dir <path> --output presentation.pptx
    
    • Script-level alternative:
    node .claude/skills/pptx-skill/scripts/html2pptx.js
    
  3. Verify results

    • Check generated PPTX file
    • Visual verification via thumbnail

Script Usage

html2pptx.js

Convert HTML files to PPTX

import { html2pptx } from './.claude/skills/pptx-skill/scripts/html2pptx.js';
import PptxGenJS from 'pptxgenjs';

const pres = new PptxGenJS();
pres.layout = 'LAYOUT_WIDE'; // 16:9

// Convert each slide
await html2pptx('<slides-dir>/slide-01.html', pres);
await html2pptx('<slides-dir>/slide-02.html', pres);

// Save
await pres.writeFile({ fileName: 'presentation.pptx' });

thumbnail.py

Generate presentation thumbnail grid

python .claude/skills/pptx-skill/scripts/thumbnail.py presentation.pptx output-thumbnail

Options:

  • --cols N: Number of columns (default 5, range 3-6)
  • --outline-placeholders: Show placeholder regions

pack.py / unpack.py

PPTX file packaging/unpackaging

# Unpack
python .claude/skills/pptx-skill/ooxml/scripts/unpack.py presentation.pptx output_dir

# Pack
python .claude/skills/pptx-skill/ooxml/scripts/pack.py input_dir presentation.pptx

validate.py

PPTX structure validation

python .claude/skills/pptx-skill/ooxml/scripts/validate.py unpacked_dir --original presentation.pptx

Reference Documents

  • html2pptx.md - HTML to PPTX conversion detailed guide
  • ooxml.md - Office Open XML technical reference

PptxGenJS Key Rules

Color Codes

// Correct - without #
{ color: 'FF0000' }

// Wrong - causes file corruption
{ color: '#FF0000' }

Adding Slides

const slide = pres.addSlide();

// Add text
slide.addText('Title', {
  x: 0.5,
  y: 0.5,
  w: 9,
  h: 1,
  fontSize: 36,
  color: '1a1a2e',
  bold: true
});

// Add image
slide.addImage({
  path: 'image.png',
  x: 1,
  y: 2,
  w: 4,
  h: 3
});

// Add shape
slide.addShape(pres.ShapeType.rect, {
  x: 0.5,
  y: 1,
  w: 3,
  h: 2,
  fill: { color: '1e3a5f' }
});

Adding Charts

// Bar chart
slide.addChart(pres.ChartType.bar, [
  {
    name: 'Series 1',
    labels: ['A', 'B', 'C'],
    values: [10, 20, 30]
  }
], {
  x: 1,
  y: 2,
  w: 8,
  h: 4
});

// Pie chart
slide.addChart(pres.ChartType.pie, [...], {...});

// Line chart
slide.addChart(pres.ChartType.line, [...], {...});

Full Conversion Process

+-------------------+
|   HTML Slides     |
| <slides-dir>/*.html |
+---------+---------+
          |
          v
+-------------------+
|  html2pptx.js     |
|  (Playwright +    |
|   PptxGenJS)      |
+---------+---------+
          |
          v
+-------------------+
|   PPTX File       |
| presentation.pptx |
+---------+---------+
          |
          v
+-------------------+
|  thumbnail.py     |
|  (Preview)        |
+-------------------+

Dependencies

Node.js

  • pptxgenjs: PowerPoint generation
  • playwright: Browser rendering
  • sharp: Image processing

Python

  • markitdown: Markdown conversion
  • defusedxml: XML parsing
  • pillow: Image processing

System

  • LibreOffice: PDF/image conversion (soffice)
  • Poppler: PDF to image (pdftoppm)

Important Notes

  1. Color codes: No # prefix in PptxGenJS
  2. Fonts: Web-safe fonts only
  3. Text: Only p, h1-h6, ul, ol tags are converted
  4. Gradients: Replace CSS gradients with images
  5. Validation: Always verify with thumbnails after conversion
Skills similaires