skill-pdf-to-pptx-tool

- Converting PDF documents to editable PowerPoint presentations

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "skill-pdf-to-pptx-tool" with this command: npx skills add dnvriend/pdf-to-pptx-tool/dnvriend-pdf-to-pptx-tool-skill-pdf-to-pptx-tool

When to use

  • Converting PDF documents to editable PowerPoint presentations

  • Creating slide decks from PDF reports or documents

  • Need high-quality PDF to PPTX conversion with custom DPI

  • Want multi-level verbosity logging for debugging conversions

PDF to PowerPoint Converter Skill

Purpose

This skill provides comprehensive guidance for using pdf-to-pptx-tool , a professional CLI tool that converts PDF documents into PowerPoint presentations. Each PDF page becomes a high-quality slide with customizable resolution.

When to Use This Skill

Use this skill when:

  • You need to convert PDF documents to PowerPoint format

  • You want to customize conversion quality (DPI settings)

  • You need to debug conversion issues with verbose logging

  • You're working with multi-page PDF documents

  • You need programmatic PDF to PPTX conversion in workflows

Do NOT use this skill for:

  • Editing existing PowerPoint files (use PowerPoint directly)

  • Converting other formats (images, Word docs) to PPTX

  • Extracting text from PDFs (use PDF text extraction tools)

  • Creating PowerPoint from scratch (use PowerPoint or python-pptx)

CLI Tool: pdf-to-pptx-tool

A modern Python CLI tool built with Click, featuring multi-level verbosity logging, shell completion, and type-safe code.

Installation

Clone the repository

git clone https://github.com/dnvriend/pdf-to-pptx-tool.git cd pdf-to-pptx-tool

Install globally with uv

uv tool install .

Prerequisites

  • Python 3.14+

  • poppler system library (for PDF rendering)

  • macOS: brew install poppler

  • Ubuntu/Debian: apt-get install poppler-utils

  • Windows: Download from poppler releases

Quick Start

Basic conversion

pdf-to-pptx-tool convert document.pdf slides.pptx

High quality (300 DPI)

pdf-to-pptx-tool convert report.pdf presentation.pptx --dpi 300

With verbose logging

pdf-to-pptx-tool -v convert input.pdf output.pptx

Progressive Disclosure

convert - Convert PDF to PowerPoint

Converts a PDF document to PowerPoint format, creating one slide per PDF page with customizable quality settings.

Usage:

pdf-to-pptx-tool convert INPUT_PDF OUTPUT_PPTX [OPTIONS]

Arguments:

  • INPUT_PDF : Path to input PDF file (required)

  • Must exist and be a valid PDF file

  • Supports any PDF version

  • No size limit (memory permitting)

  • OUTPUT_PPTX : Path to output PowerPoint file (required)

  • Will be created or overwritten

  • Extension should be .pptx

  • Parent directory must exist

  • --dpi INTEGER : Resolution for page conversion (optional)

  • Default: 200 DPI (good quality, reasonable size)

  • Range: 72-600 DPI

  • Higher DPI = better quality but larger files

  • Recommended: 200-300 for presentations

  • -v, --verbose : Multi-level verbosity

  • No flag: Warnings/errors only

  • -v : INFO level (operations and progress)

  • -vv : DEBUG level (detailed steps)

  • -vvv : TRACE level (library internals)

Examples:

Example 1: Basic conversion (default 200 DPI)

pdf-to-pptx-tool convert quarterly-report.pdf q4-presentation.pptx

Example 2: High quality for detailed diagrams

pdf-to-pptx-tool convert technical-diagram.pdf slides.pptx --dpi 300

Example 3: Lower quality for quick preview

pdf-to-pptx-tool convert draft.pdf preview.pptx --dpi 150

Example 4: With INFO logging to see progress

pdf-to-pptx-tool -v convert large-doc.pdf output.pptx

Example 5: With DEBUG logging for troubleshooting

pdf-to-pptx-tool -vv convert problematic.pdf fixed.pptx

Example 6: Batch conversion with shell loop

for pdf in *.pdf; do pdf-to-pptx-tool convert "$pdf" "${pdf%.pdf}.pptx" done

Output:

  • Creates PowerPoint file at specified path

  • Slide properties:

  • Aspect ratio: 16:9 (widescreen)

  • Dimensions: 10" × 5.625"

  • Layout: One full-slide image per PDF page

  • Background: Transparent

  • Console output:

  • Success: "✓ Successfully converted input.pdf to output.pptx"

  • Error: "✗ Error: [detailed error message]"

  • Exit codes:

  • 0: Success

  • 1: Error (file not found, invalid input, conversion failed)

completion - Generate shell completion scripts

Generates shell completion scripts for bash, zsh, or fish shells.

Usage:

pdf-to-pptx-tool completion SHELL

Arguments:

  • SHELL : Shell type (required)

  • Options: bash , zsh , fish

  • Case-insensitive

Examples:

Generate bash completion

eval "$(pdf-to-pptx-tool completion bash)"

Generate zsh completion

eval "$(pdf-to-pptx-tool completion zsh)"

Generate fish completion

pdf-to-pptx-tool completion fish | source

Save to file for permanent installation

pdf-to-pptx-tool completion bash > ~/.pdf-to-pptx-tool-completion.bash echo 'source ~/.pdf-to-pptx-tool-completion.bash' >> ~/.bashrc

Output: Shell-specific completion script printed to stdout.

Multi-Level Verbosity Logging

The tool supports progressive verbosity levels for debugging and monitoring conversions.

Logging Levels:

Flag Level Output Use Case

(none) WARNING Errors/warnings only Production, quiet mode

-v

INFO

  • Operations, progress Normal debugging

-vv

DEBUG

  • Detailed steps, file sizes Development, troubleshooting

-vvv

TRACE

  • Library internals (pdf2image, PIL, pptx) Deep debugging

Examples:

Quiet mode - only see errors

pdf-to-pptx-tool convert input.pdf output.pptx

INFO - see conversion progress

pdf-to-pptx-tool -v convert input.pdf output.pptx

Output:

[INFO] Starting PDF to PPTX conversion

[INFO] Converting input.pdf to output.pptx (DPI: 200)

[INFO] Converting PDF pages to images...

[INFO] Converted 5 pages

[INFO] Creating PowerPoint presentation...

[INFO] Saving presentation to output.pptx

DEBUG - see detailed processing

pdf-to-pptx-tool -vv convert input.pdf output.pptx

Additional output:

[DEBUG] Input: input.pdf, Output: output.pptx, DPI: 200

[DEBUG] Validating input file: input.pdf

[DEBUG] Input file size: 2.45 MB

[DEBUG] Using DPI setting: 200

[DEBUG] Processing slide 1/5

[DEBUG] Output file size: 8.23 MB

TRACE - see library internals

pdf-to-pptx-tool -vvv convert input.pdf output.pptx

Shows pdf2image, PIL, and pptx library debug messages

DPI Quality Guidelines

Choose DPI based on your use case:

DPI Quality File Size Best For

72 Low Smallest Quick previews, draft slides

150 Medium Small Web presentations, email

200 Good Medium Default - recommended for most

300 High Large Print quality, detailed diagrams

600 Very High Very Large Professional print, posters

Trade-offs:

  • Higher DPI: Better quality, larger file size, slower conversion

  • Lower DPI: Faster conversion, smaller files, lower quality

  • Sweet spot: 200-300 DPI for most presentations

Batch Processing

Process multiple PDFs efficiently:

Convert all PDFs in directory

for pdf in *.pdf; do echo "Converting $pdf..." pdf-to-pptx-tool convert "$pdf" "${pdf%.pdf}.pptx" done

With custom DPI

for pdf in *.pdf; do pdf-to-pptx-tool convert "$pdf" "${pdf%.pdf}.pptx" --dpi 300 done

With error handling

for pdf in *.pdf; do if pdf-to-pptx-tool -v convert "$pdf" "${pdf%.pdf}.pptx"; then echo "✓ Converted $pdf" else echo "✗ Failed to convert $pdf" fi done

Shell Completion

Enable tab completion for faster usage:

Bash - add to ~/.bashrc

eval "$(pdf-to-pptx-tool completion bash)"

Zsh - add to ~/.zshrc

eval "$(pdf-to-pptx-tool completion zsh)"

Fish - save to completions directory

mkdir -p ~/.config/fish/completions pdf-to-pptx-tool completion fish > ~/.config/fish/completions/pdf-to-pptx-tool.fish

Benefits:

  • Tab-complete commands: pdf-to-pptx-tool <TAB>

  • Tab-complete options: pdf-to-pptx-tool convert --<TAB>

  • Tab-complete file paths automatically

Common Issues

Issue: "poppler not found" or PDF conversion fails

Symptom

RuntimeError: Failed to convert PDF pages: poppler not found

Solution: Install poppler system library:

macOS

brew install poppler

Ubuntu/Debian

sudo apt-get install poppler-utils

Fedora

sudo dnf install poppler-utils

Verify installation

pdftoppm -v

Issue: "File not found" error

Symptom

✗ Error: Input PDF file not found: document.pdf

Solution:

  • Verify file path is correct

  • Use absolute paths if needed

  • Check file permissions

Check file exists

ls -l document.pdf

Use absolute path

pdf-to-pptx-tool convert /full/path/to/document.pdf output.pptx

Issue: Output file is too large

Symptom

Generated 50MB PPTX from 2MB PDF

Solution: Reduce DPI setting:

Try lower DPI

pdf-to-pptx-tool convert input.pdf output.pptx --dpi 150

Or use default 200 DPI

pdf-to-pptx-tool convert input.pdf output.pptx

Issue: Images look blurry in PowerPoint

Symptom

Text and diagrams appear pixelated

Solution: Increase DPI setting:

Use higher quality

pdf-to-pptx-tool convert input.pdf output.pptx --dpi 300

For print quality

pdf-to-pptx-tool convert input.pdf output.pptx --dpi 600

Issue: Conversion is very slow

Symptom

Large PDF takes minutes to convert

Solution:

  • Use DEBUG logging to see progress:

pdf-to-pptx-tool -vv convert large.pdf output.pptx

  • Consider lower DPI for faster conversion:

pdf-to-pptx-tool convert large.pdf output.pptx --dpi 150

  • Split large PDF into chunks and convert separately

Issue: Permission denied writing output file

Symptom

PermissionError: [Errno 13] Permission denied: 'output.pptx'

Solution:

  • Check directory write permissions

  • Use different output location

Write to home directory

pdf-to-pptx-tool convert input.pdf ~/output.pptx

Or create directory first

mkdir -p output-dir pdf-to-pptx-tool convert input.pdf output-dir/output.pptx

Getting Help

Tool help

pdf-to-pptx-tool --help

Command help

pdf-to-pptx-tool convert --help

Completion help

pdf-to-pptx-tool completion --help

Version info

pdf-to-pptx-tool --version

Debug Workflow

When conversion fails, use this debugging workflow:

1. Check file exists and is readable

ls -lh document.pdf file document.pdf

2. Verify poppler is installed

pdftoppm -v

3. Try with DEBUG logging

pdf-to-pptx-tool -vv convert document.pdf test.pptx

4. Try with lower DPI if memory issues

pdf-to-pptx-tool -vv convert document.pdf test.pptx --dpi 150

5. Check Python and dependencies

python --version pdf-to-pptx-tool --version

Exit Codes

  • 0 : Success - conversion completed successfully

  • 1 : Error - file not found, invalid input, conversion failed, or permission denied

Output Formats

Default PowerPoint Output:

  • Format: Office Open XML (.pptx)

  • Aspect Ratio: 16:9 widescreen

  • Slide Size: 10 inches × 5.625 inches

  • Layout: One full-slide image per PDF page

  • Image Format: PNG embedded in slides

  • Compatibility: PowerPoint 2007+ (Windows/Mac/Online)

Console Output:

Success

✓ Successfully converted document.pdf to slides.pptx

Error

✗ Error: Input PDF file not found: document.pdf

Logging Output (with -v/-vv/-vvv):

[INFO] Starting PDF to PPTX conversion [INFO] Converting document.pdf to slides.pptx (DPI: 200) [DEBUG] Input file size: 2.45 MB [INFO] Converted 10 pages [DEBUG] Output file size: 12.78 MB [INFO] Conversion completed successfully

Best Practices

  • Start with default DPI (200): Good balance of quality and file size

  • Use verbose logging for debugging: -vv shows detailed conversion steps

  • Test with sample PDFs first: Verify quality before batch processing

  • Monitor output file sizes: Adjust DPI if files are too large

  • Batch process efficiently: Use shell loops for multiple files

  • Enable shell completion: Speeds up command-line usage

  • Keep poppler updated: Ensures compatibility with latest PDF features

  • Use absolute paths: Avoids confusion with relative paths

  • Verify prerequisites: Check poppler installation before bulk conversions

  • Handle errors gracefully: Check exit codes in scripts

Resources

  • GitHub Repository: https://github.com/dnvriend/pdf-to-pptx-tool

  • Python Dependencies:

  • pdf2image (PDF to image conversion)

  • python-pptx (PowerPoint file creation)

  • Pillow (Image processing)

  • Click (CLI framework)

  • System Dependencies: poppler (PDF rendering engine)

  • Related Tools:

  • PyPDF2 (PDF text extraction)

  • ReportLab (PDF generation)

  • pandoc (Universal document converter)

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

image-gen

Generate AI images from text prompts. Triggers on: "生成图片", "画一张", "AI图", "generate image", "配图", "create picture", "draw", "visualize", "generate an image".

Archived SourceRecently Updated
General

explainer

Create explainer videos with narration and AI-generated visuals. Triggers on: "解说视频", "explainer video", "explain this as a video", "tutorial video", "introduce X (video)", "解释一下XX(视频形式)".

Archived SourceRecently Updated
General

asr

Transcribe audio files to text using local speech recognition. Triggers on: "转录", "transcribe", "语音转文字", "ASR", "识别音频", "把这段音频转成文字".

Archived SourceRecently Updated
General

axure-prototype-generator

Axure 原型代码生成器 - 输出 JavaScript 格式 HTML 代码,支持内联框架直接加载可交互原型

Archived SourceRecently Updated