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)

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-0.0.4.tar.gz (183.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-0.0.4-py3-none-any.whl (6.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: pdf2md_ocr-0.0.4.tar.gz
  • Upload date:
  • Size: 183.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-0.0.4.tar.gz
Algorithm Hash digest
SHA256 797d296194254d356ddb226af0252b140c1d0b56ca212b4f1f72122e0f1ce81e
MD5 78f760fd13dee4ed5b5421baccc1e2f1
BLAKE2b-256 0555bce2b551ebc674f21b6048b74e1f74272405db6758ec45f0df243806e17e

See more details on using hashes here.

Provenance

The following attestation bundles were made for pdf2md_ocr-0.0.4.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-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: pdf2md_ocr-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 6.0 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-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 c74a56b80f32d745115e20d2e9338b79ed7eee996d8897608ed49cbe660c984e
MD5 8f1474089868b46b0285c1b78f730451
BLAKE2b-256 4e17e1e2bba5aa692611355441a92f1ba49270538c6a52d048db637e4ec8fd8f

See more details on using hashes here.

Provenance

The following attestation bundles were made for pdf2md_ocr-0.0.4-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