OCRmyPDF adds an OCR text layer to scanned PDF files, allowing them to be searched or copy-pasted.
ocrmypdf # it's a scriptable command line program -l eng+fra # it supports multiple languages --rotate-pages # it can fix pages that are misrotated --deskew # it can deskew crooked PDFs! --title "My PDF" # it can change output metadata --jobs 4 # it uses multiple cores by default --output-type pdfa # it produces PDF/A by default input_scanned.pdf # takes PDF input (or images) output_searchable.pdf # produces validated PDF output
- Generates a searchable PDF/A file from a regular PDF
- Places OCR text accurately below the image to ease copy / paste
- Keeps the exact resolution of the original embedded images
- When possible, inserts OCR information as a "lossless" operation without disrupting any other content
- Optimizes PDF images, often producing files smaller than the input file
- If requested, deskews and/or cleans the image before performing OCR
- Validates input and output files
- Distributes work across all available CPU cores
- Uses Tesseract OCR engine to recognize more than 100 languages
- Scales properly to handle files with thousands of pages
- Battle-tested on millions of PDFs
For details: please consult the documentation.
I searched the web for a free command line tool to OCR PDF files: I found many, but none of them were really satisfying:
- Either they produced PDF files with misplaced text under the image (making copy/paste impossible)
- Or they did not handle accents and multilingual characters
- Or they changed the resolution of the embedded images
- Or they generated ridiculously large PDF files
- Or they crashed when trying to OCR
- Or they did not produce valid PDF files
- On top of that none of them produced PDF/A files (format dedicated for long time storage)
...so I decided to develop my own tool.
Linux, Windows, macOS and FreeBSD are supported. Docker images are also available, for both x64 and ARM.
|Operating system||Install command|
|Debian, Ubuntu||apt install ocrmypdf|
|Windows Subsystem for Linux||apt install ocrmypdf|
|Fedora||dnf install ocrmypdf|
|macOS||brew install ocrmypdf|
|LinuxBrew||brew install ocrmypdf|
|FreeBSD||pkg install py37-ocrmypdf|
|Conda||conda install ocrmypdf|
For everyone else, see our documentation for installation steps.
OCRmyPDF uses Tesseract for OCR, and relies on its language packs. For Linux users, you can often find packages that provide language packs:
# Display a list of all Tesseract language packs apt-cache search tesseract-ocr # Debian/Ubuntu users apt-get install tesseract-ocr-chi-sim # Example: Install Chinese Simplified language pack # Arch Linux users pacman -S tesseract-data-eng tesseract-data-deu # Example: Install the English and German language packs # brew macOS users brew install tesseract-lang
You can then pass the
-l LANG argument to OCRmyPDF to give a hint as to what languages it should search for. Multiple languages can be requested.
Documentation and support
Once OCRmyPDF is installed, the built-in help which explains the command syntax and options can be accessed via:
Please report issues on our GitHub issues page, and follow the issue template for quick response.
In addition to the required Python version (3.6+), OCRmyPDF requires external program installations of Ghostscript, Tesseract OCR, QPDF, and Leptonica. OCRmyPDF is pure Python, but uses CFFI to portably generate library bindings. OCRmyPDF works on pretty much everything: Linux, macOS, Windows and FreeBSD.