Jim Barlow cc2af2bc15 Convert the final image to a JPEG if the original image was a JPEG
Of course, this introduces recompression artifacts, and is unnecessary
if no options are given that modify the final image (no -d, -c, -i).
But rather than worry about that, it would be better to ultimately find
a way to combine the original PDF page with the output PDF text in the
case where we want no changes to the original. This is good enough for
now.

The better option can apparently be achieved using pdftk background, or
probably better, PyPDF2's merge. If Tesseract PDF generation is used
then we need a way to remove the image. Tesseract PDF generation at 3.03
does layout better (I think) and also properly encodes the hidden layer,
which is less likely to give display issues (I think).
2015-02-11 10:23:45 -08:00
2014-09-24 23:17:39 +02:00
2014-04-27 15:46:55 +02:00
2013-05-06 23:13:29 +03:00
2014-09-20 20:47:02 +02:00

OCRmyPDF

OCRmyPDF adds an OCR text layer to scanned PDF files, allowing them to be searched

To get the script usage, call: sh ./OCRmyPDF.sh -h

Main features

  • Generates a searchable PDF/A file from a PDF file containing only images
  • Places OCRed text accurately below the image to ease copy / paste
  • Keeps the exact resolution of the original embedded images
    • or if requested oversamples the images before OCRing so as to get better results
  • If requested deskews and / or clean the image before performing OCR
  • Validates the generated file against the PDF/A specification using jhove
  • Provides debug mode to enable easy verification of the OCR results
  • Processes several pages in parallel if more than one CPU core is available

For details: please consult the release notes

Motivation

I searched the web for a free command line tool to OCR PDF files on linux/unix: 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 display correctly some escaped html characters located in the hocr file produced by the OCR engine
  • Or they changed the resolution of the embedded images
  • Or they generated PDF file having a ridiculous big size
  • Or they crashed when trying to OCR some of my PDF files
  • Or they did not produce valid PDF files (even though they were readable with my current PDF reader)
  • On top of that none of them produced PDF/A files (format dedicated for long time storage / archiving)

... so I decided to develop my own tool (using various existing scripts as an inspiration)

Install

Download OCRmyPDF here: https://github.com/fritz-hh/OCRmyPDF/releases

Copy the file in onto your linux/unix machine and extract it.

Run: "sh ./OCRmyPDF.sh -h" to get the script usage

If not yet installed, the script will notify you about dependencies that need to be installed. The script requires specific versions of the dependencies. Older version than the ones mentioned in the release notes are likely not to be compatible to OCRmyPDF.

Support

In case you detect an issue, please:

  • Check if your issue is already known
  • If no problem report exists on github, please create one here: https://github.com/fritz-hh/OCRmyPDF/issues
  • Describe your problem thoroughly
  • Append the console output of the script when running the debug mode (-g option)
  • If possible provide your input PDF file as well as the content of the temporary folder (using a file sharing service like www.file-upload.net)

Press & Media

Disclaimer

The software is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.

Description
OCRmyPDF adds an OCR text layer to scanned PDF files, allowing them to be searched
Readme MPL-2.0 77 MiB
Languages
Python 96.9%
Shell 2.7%
Dockerfile 0.4%