Skip to main content

A local-first CLI (and optional Web UI) for converting PDFs and image folders into clean, DPI-controlled PowerPoint slides

Project description

PPTX Builder

License: MIT Python 3.8+ Tests

A local-first CLI (and optional Web UI) for converting PDFs and image folders into clean, DPI-controlled PowerPoint slides — no PowerPoint required.


Quick Start

pip install pptx-builder
pptx-builder -i document.pdf

Why This Exists

  • Privacy: Process files locally without uploading to online converters.
  • Predictable output: A deterministic raster pipeline produces clean slides, avoiding fragile "editable" conversions that attempt unreliable text reconstruction.
  • Power-tool behavior: Full control over DPI, aspect ratio, and placement — no surprise auto-fit or re-layout.

This tool deliberately favors consistent, high-quality raster output over attempts to reconstruct editable slide content.


Installation

Via pip (Recommended)

pip install pptx-builder

System dependencies:

  • poppler-utils (required for PDF conversion)

    • Debian/Ubuntu: sudo apt install poppler-utils
    • macOS: brew install poppler

With Web UI (Optional)

pip install "pptx-builder[web]"

Run the web interface:

python -m pptx_builder.web

Docker (Web UI)

git clone https://github.com/sageframe-no-kaji/pptx-builder.git
cd pptx-builder
docker compose up -d

Access the interface at: http://localhost:7860

See DOCKER.md for details.


Usage

CLI (Primary Interface)

Interactive mode:

pptx-builder

CLI examples:

# Convert a PDF
pptx-builder -i document.pdf

# Custom output name
pptx-builder -i document.pdf -o slides.pptx

# Higher DPI (slower, sharper)
pptx-builder -i document.pdf --dpi 600

# Process folder of images
pptx-builder -i photos/

# Batch process multiple files
pptx-builder -i file1.pdf file2.pdf --quiet --force

# Process folder recursively
pptx-builder -i images/ --recursive

# Enable verbose logging
pptx-builder -i document.pdf --verbose

Common options:

  • -i, --input PATH — Input file(s) or folder
  • -o, --output NAME — Output filename (single input only)
  • --dpi DPI — PDF rendering quality (default: 300)
  • -r, --recursive — Process subfolders
  • --quiet — Suppress prompts and non-critical output
  • --force — Overwrite existing files
  • --verbose — Enable debug logging
  • -h, --help — Show all options

Web UI (Secondary Interface)

If installed with [web] extras or via Docker:

python -m pptx_builder.web

Or:

docker compose up -d
# Open http://localhost:7860

Upload files, select options, download presentation.


Features

Supported Formats

  • PDF (multi-page supported)
  • Images: PNG, JPG, JPEG, TIFF, WebP, BMP, GIF, ICO, HEIC, HEIF

Slide Sizes

  • 16:9 Widescreen (13.33" × 7.5") — default
  • 4:3 Standard (10" × 7.5")
  • Letter (11" × 8.5")
  • A4 (11.69" × 8.27")
  • Legal (14" × 8.5")
  • Tabloid (17" × 11")

Image Placement Modes

  • Fit — No cropping; entire image visible (default)
  • Fill — No whitespace; may crop edges

Output Behavior

  • One slide per image or PDF page
  • Images sorted alphabetically
  • Centered, never stretched
  • Compatible with PowerPoint, LibreOffice, and Google Slides

Documentation


Development

Setup

git clone https://github.com/sageframe-no-kaji/pptx-builder.git
cd pptx-builder
pip install -e .[dev]

Run Tests

pytest
pytest --cov=pptx_builder --cov-report=html

Code Quality

black src/
flake8 src/pptx_builder/
mypy src/pptx_builder/

Pre-commit Hooks

pre-commit install
pre-commit run --all-files

Notes

  • 150–300 DPI recommended for most use cases (600 DPI is slower but sharper)
  • Large PDFs (30+ pages) at 300 DPI may take 30–60 seconds
  • Temporary files are cleaned up automatically; no persistent storage is used
  • HEIC/HEIF require pillow-heif (included)

Author

Created by Andrew T. Marcus GitHub: https://github.com/sageframe-no-kaji


License

MIT License — see LICENSE.


Contributing

Issues and pull requests welcome:

https://github.com/sageframe-no-kaji/pptx-builder

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

sageframe_pptx_builder-0.1.0.tar.gz (16.7 kB view details)

Uploaded Source

Built Distribution

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

sageframe_pptx_builder-0.1.0-py3-none-any.whl (15.7 kB view details)

Uploaded Python 3

File details

Details for the file sageframe_pptx_builder-0.1.0.tar.gz.

File metadata

  • Download URL: sageframe_pptx_builder-0.1.0.tar.gz
  • Upload date:
  • Size: 16.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.2

File hashes

Hashes for sageframe_pptx_builder-0.1.0.tar.gz
Algorithm Hash digest
SHA256 1fc2907b2640258a1ef16be21ee7ab244bad6d0a2ba442ed094d3e8600f860cb
MD5 6bf1494adf014c5105b246afcdd99fb7
BLAKE2b-256 0d1644ff20677afdeaa780d202dc0d08f3c2bc575a46bf561c83be6c4f67d9d5

See more details on using hashes here.

File details

Details for the file sageframe_pptx_builder-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for sageframe_pptx_builder-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 0fe30ea247b5f641b1c7d2323cb5bb003839fc3964926809d6fcc62b105b71ab
MD5 c0d12ee03cc5605eaa4763293015738e
BLAKE2b-256 eeb3bfb574839461cda2bb5a47b11be501436f0407e60b52e07801a26d34493a

See more details on using hashes here.

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