A local-first CLI (and optional Web UI) for converting PDFs and image folders into clean, DPI-controlled PowerPoint slides
Project description
PPTX Builder
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
- Debian/Ubuntu:
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
- DOCKER.md — Docker deployment
- CONTRIBUTING.md — Development guidelines
- docs/GRADIO_TUTORIAL.md — Web UI technical guide
- docs/MAN_PAGE_USAGE.md — Man page instructions
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:
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
1fc2907b2640258a1ef16be21ee7ab244bad6d0a2ba442ed094d3e8600f860cb
|
|
| MD5 |
6bf1494adf014c5105b246afcdd99fb7
|
|
| BLAKE2b-256 |
0d1644ff20677afdeaa780d202dc0d08f3c2bc575a46bf561c83be6c4f67d9d5
|
File details
Details for the file sageframe_pptx_builder-0.1.0-py3-none-any.whl.
File metadata
- Download URL: sageframe_pptx_builder-0.1.0-py3-none-any.whl
- Upload date:
- Size: 15.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.2
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
0fe30ea247b5f641b1c7d2323cb5bb003839fc3964926809d6fcc62b105b71ab
|
|
| MD5 |
c0d12ee03cc5605eaa4763293015738e
|
|
| BLAKE2b-256 |
eeb3bfb574839461cda2bb5a47b11be501436f0407e60b52e07801a26d34493a
|