Skip to main content

Simple CLI tool to convert PDFs to Markdown using Marker AI

Project description

pdf2md-ocr

Simple CLI tool to convert PDFs to Markdown using Marker AI.

Quick Start

Recommended (no installation needed):

uvx pdf2md-ocr input.pdf -o output.md

Traditional installation:

pip install pdf2md-ocr
pdf2md-ocr input.pdf -o output.md

Usage

# Convert PDF to Markdown (output same name with .md extension)
pdf2md-ocr document.pdf

# Specify output file
pdf2md-ocr document.pdf -o result.md

# Convert specific page range (page numbering starts at 1)
pdf2md-ocr document.pdf --start-page 2 --end-page 5

# Convert from page 3 to the end
pdf2md-ocr document.pdf --start-page 3

# Convert from the beginning to page 10
pdf2md-ocr document.pdf --end-page 10

# Show cache location and size
pdf2md-ocr document.pdf --show-cache-info

# Show help
pdf2md-ocr --help

# Show version
pdf2md-ocr --version

Page Range Options

  • --start-page N: Starting page number (1-based, inclusive). If omitted, starts from page 1.
  • --end-page M: Ending page number (1-based, inclusive). If omitted, goes to the last page.

Both options are optional and can be combined:

  • Use only --start-page to convert from a specific page to the end.
  • Use only --end-page to convert from the beginning to a specific page.
  • Use both to convert a specific range.

Important: Page numbering starts at 1 (not 0).

First Run

The first time you run pdf2md-ocr, it will download ~2-3GB of AI models. These models are cached locally and reused for all future conversions.

To see where models are cached:

pdf2md-ocr input.pdf --show-cache-info

This will show the cache location and size after conversion. Cache locations, typically:

  • macOS: ~/Library/Caches/datalab/models/
  • Linux: ~/.cache/datalab/models/
  • Windows: %LOCALAPPDATA%\datalab\models\

To clear the cache: Simply delete the cache directory shown in the info above, or use make clean-cache if developing locally.

Subsequent runs will be much faster since the models are already cached.

Requirements

  • Python 3.10 or higher
  • ~2GB disk space for AI models (one-time download)

System Requirements

pdf2md-ocr requires native system libraries for PDF processing. These need to be installed separately on your system:

macOS (Homebrew)

brew install gobject-introspection pango
export DYLD_LIBRARY_PATH="/opt/homebrew/lib:$DYLD_LIBRARY_PATH"

For permanent setup, add the export line to your shell profile (~/.zshrc, ~/.bash_profile, etc.):

echo 'export DYLD_LIBRARY_PATH="/opt/homebrew/lib:$DYLD_LIBRARY_PATH"' >> ~/.zshrc

Linux (Ubuntu/Debian)

sudo apt-get update
sudo apt-get install libgobject-2.0-0 libpango-1.0-0

Linux (Fedora/RHEL)

sudo dnf install gobject-introspection pango

Windows

Download and install GTK+ 3 from the GTK-for-Windows-Runtime-Environment-Installer.

Development

For development, a Makefile is provided with common tasks:

# Install dependencies
make install-dev

# Run tests
make test

# Run tests with verbose output
make test-verbose

# Clean build artifacts
make clean

# Clear AI model cache (frees ~3GB disk space)
make clean-cache

# Build distribution packages
make build

# See all available commands
make help

How It Works

This tool is a minimal wrapper around the excellent marker-pdf library, which uses AI models to:

  1. Detect text, tables, and equations in PDFs
  2. Extract content with proper formatting
  3. Convert to clean Markdown

License

GPL-3.0-or-later

This project is licensed under the GNU General Public License v3.0 or later to comply with the marker-pdf library license (GPL-3.0-or-later).

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

pdf2md_ocr-1.0.1.tar.gz (188.9 kB view details)

Uploaded Source

Built Distribution

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

pdf2md_ocr-1.0.1-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file pdf2md_ocr-1.0.1.tar.gz.

File metadata

  • Download URL: pdf2md_ocr-1.0.1.tar.gz
  • Upload date:
  • Size: 188.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for pdf2md_ocr-1.0.1.tar.gz
Algorithm Hash digest
SHA256 93ba2e7dc2fe40d627479a295843aa4ef2d44a12c19c3ddc9fe2ff348eb52708
MD5 513f523457bcff99eeaca6bff2bf6670
BLAKE2b-256 4c6c22d367e6e52d37f6d8947fe7ed76e2697767dc06dd799622358f0af259be

See more details on using hashes here.

Provenance

The following attestation bundles were made for pdf2md_ocr-1.0.1.tar.gz:

Publisher: publish-to-pypi.yml on carloscasalar/pdf2md-ocr

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

File details

Details for the file pdf2md_ocr-1.0.1-py3-none-any.whl.

File metadata

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

File hashes

Hashes for pdf2md_ocr-1.0.1-py3-none-any.whl
Algorithm Hash digest
SHA256 b2e5c28926c41ac800ea63b2a0c6b818953230e64cec1ccd941802ee7107ea4e
MD5 67ca7fc6ad5af43c893629cba11e3665
BLAKE2b-256 dc749cf677fcfd559ef6453fa2c99257365e91e6307bfa520426840f262fecdd

See more details on using hashes here.

Provenance

The following attestation bundles were made for pdf2md_ocr-1.0.1-py3-none-any.whl:

Publisher: publish-to-pypi.yml on carloscasalar/pdf2md-ocr

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