Skip to main content

Local-first document translation and conversion toolkit

Project description

Loctran — private AI PDF translator

CI PyPI License Python

Translate PDFs locally. No cloud. No API key. Just Ollama.

Features

What it does Why it matters
Rasterises PDFs with pypdfium2 No Poppler / Ghostscript dependency
Dual-pass OCR (Tesseract + inverted image) Catches light-on-dark and low-contrast text
Batched LLM translation via Ollama Works with any local chat model
HTML overlay output Translations positioned over the original layout
Web UI with real-time progress Upload and translate from any browser
PDF compression Reduce file size without proprietary tools
100 % local — files never leave your machine Full privacy, no API keys, works offline

Screenshots

1. Home 1.1 PDF Upload
1. Home 1.1 PDF Upload
2. Translation Configured 2.1 Translation In Progress
2. Translation Configured 2.1 Translation In Progress
3. Result 3.1 Translation Complete
3. Result 3.1 Translation Complete

30-second install

The default install includes the Web UI. A plain pip install loctran is enough to start the app.

pip install loctran
ollama pull glm-ocr
ollama pull translategemma:4b
loctran
# opens Web UI at http://127.0.0.1:8000
# CLI translation example
loctran translate document.pdf --lang French

How it works

PDF
 └─► rasterise pages (pypdfium2)
      └─► dual-pass OCR (Tesseract normal + inverted)
           └─► deduplicate & group words into segments
                └─► batch translate (Ollama LLM)
                     └─► HTML overlay output

Each page becomes an image with absolutely-positioned translation boxes sized to match the original text bounding boxes. For PDFs with a digital text layer, pdfplumber extracts text directly — no OCR needed.


Requirements

  • OS: macOS, Linux, or Windows
  • Python ≥ 3.9
  • Ollama running locally — download
  • Tesseractbrew install tesseract tesseract-lang (macOS) or apt install tesseract-ocr tesseract-ocr-all (Linux)

On startup, Loctran will try to start Ollama if it is installed and will pull the configured OCR and translation models when they are missing. The first launch still depends on the user having Ollama available and network access for any model downloads.

Run loctran doctor to check everything at once:

loctran-doctor v0.1.1b9
─────────────────────────────────────
✓  Python         3.11.9
✓  Tesseract      5.3.4  (langs: eng fra deu jpn +47)
✓  Ollama         0.3.1  (running)
✓  glm-ocr        pulled (2.2 GB)
✓  translategemma:4b pulled (3.3 GB)
─────────────────────────────────────
All required dependencies satisfied.

Web UI

Start the server and open your browser:

loctran serve
# → http://localhost:8000

Upload a PDF, choose a target language and model, then watch the real-time progress bar. The translated HTML opens automatically when done.


CLI reference

Usage: loctran [OPTIONS] COMMAND [ARGS]...

Commands:
  serve      Run the local web UI server.
  translate  Translate a file or folder using local OCR + Ollama.
  doctor     Run environment diagnostics for dependencies and models.
# Translate to Spanish using a higher-quality translation model
loctran translate report.pdf --lang Spanish --model translategemma:12b

# Extract text only, save to custom folder
loctran translate scan.pdf --extract-only --output ~/Desktop/extracted

# Use smaller batches to avoid context overflow on long documents
loctran translate book.pdf --lang German --batch-size 3

# Run dependency diagnostics
loctran doctor

Updating README screenshots

pip install -e ".[dev]"
python -m playwright install chromium
make screenshots

This writes screenshots to docs/screenshots/ using scripts/capture_screenshots.py.


FAQ

Does this send my documents anywhere? No. Everything runs locally on your machine. Loctran talks only to Ollama at localhost:11434. No telemetry, no analytics, no cloud.

Which Ollama models work? Any locally installed Ollama model appears in the Loctran model picker automatically. Run ollama list to see what is available. For this project, use glm-ocr for OCR and translategemma:4b for translation. On 16 GB+ machines, translategemma:12b is the higher-quality option.

What about scanned PDFs? Loctran automatically detects whether a PDF has a digital text layer. If it does, pdfplumber extracts text directly (fast, accurate). If not — or if you pass --force-ocr — Tesseract runs a dual-pass OCR (normal + inverted image) to catch light-on-dark text. Pass --use-ai-ocr to route OCR through an Ollama vision model for the highest accuracy on complex layouts.


Docker

docker run -p 8000:8000 -v ~/Documents:/docs ghcr.io/anzalks/loctran

Contributing

See CONTRIBUTING.md for development setup, running tests, and submitting PRs.


License

License

Apache 2.0 — © 2026 Anzal K Shahul

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

loctran-0.1.1b9.tar.gz (63.3 kB view details)

Uploaded Source

Built Distribution

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

loctran-0.1.1b9-py3-none-any.whl (47.6 kB view details)

Uploaded Python 3

File details

Details for the file loctran-0.1.1b9.tar.gz.

File metadata

  • Download URL: loctran-0.1.1b9.tar.gz
  • Upload date:
  • Size: 63.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for loctran-0.1.1b9.tar.gz
Algorithm Hash digest
SHA256 f6565f3d8aed7fa93f5273cf0fa5f91a7f412f6ddb2fb41f90cbd39070faed3b
MD5 6f611d8f3c0d931b1509b9a760f91327
BLAKE2b-256 77baaf2cc1a286a083bcd17ec4c60c3b7eea0f79a1cab4d8748f66d649c2f4b6

See more details on using hashes here.

Provenance

The following attestation bundles were made for loctran-0.1.1b9.tar.gz:

Publisher: release.yml on anzalks/loctran

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

File details

Details for the file loctran-0.1.1b9-py3-none-any.whl.

File metadata

  • Download URL: loctran-0.1.1b9-py3-none-any.whl
  • Upload date:
  • Size: 47.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for loctran-0.1.1b9-py3-none-any.whl
Algorithm Hash digest
SHA256 17a20e45755320e0e15cbfb4c8228bf96f874f35f88880230dcaf4c24fa603ee
MD5 b518363673543de5343e3ed21c9981a9
BLAKE2b-256 cd06129f4fa6931fe276ee7b543411564bb3cf8dae98af2bbdb7493450f6f0be

See more details on using hashes here.

Provenance

The following attestation bundles were made for loctran-0.1.1b9-py3-none-any.whl:

Publisher: release.yml on anzalks/loctran

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