Skip to main content

A contextual spellchecker for OCR output

Project description

python versions supported

OCRfixr

OVERVIEW

This project aims to help automate the challenging work of manually correcting OCR output from Distributed Proofreaders' book digitization projects

Correcting OCR Misreads

OCRs can sometimes mistake similar-looking characters when scanning a book. For example, "l" and "1" are easily confused, potentially causing the OCR to misread the word "learn" as "1earn".

As written in book:

"The birds flevv south"

Corrected text:

"The birds flew south"

How OCRfixr Works:

OCRfixr fixes misreads by checking 1) possible spell corrections against the 2) local context of the word. For example, here's how OCRfixr would evaluate the following OCR mistake:

As written in book:

"Days there were when small trade came to the stoie. Then the young clerk read."

Method Plausible Replacements
Spellcheck (symspellpy) stone, store, stoke, stove, stowe, stole, soie
Context (BERT) market, shop, town, city, store, table, village, door, light, markets, surface, place, window, docks, area

Since there is match for both a plausible spellcheck replacement and that word reasonably matches the context of the sentence, OCRfixr updates the word.

Corrected text:

"Days there were when small trade came to the store. Then the young clerk read."

For very common scanning errors where it is clear what the word should have been (ex: 'onlv' --> 'only'), OCRfixr skips the context check and relies solely on a static mapping of common corrections. This helps to maximize the number of successful edits & decrease compute time. (You can disable this by setting common_scannos to "F").

Using OCRfixr

The package can be installed using pip.

pip install OCRfixr

By default, OCRfixr only returns the original string, with all changes incorporated:

>>> from ocrfixr import spellcheck

>>> text = "The birds flevv south"
>>> spellcheck(text).fix()
'The birds flew south'

Use return_fixes to also include all corrections made to the text, with associated counts for each:

>>> spellcheck(text, return_fixes = "T").fix()
['The birds flew south', {("flevv","flew"):1}]

(Note: OCRfixr resets its BERT context window at the start of each new paragraph, so splitting by paragraph may be a useful debug feature)

Interactive Mode

OCRfixr also has an option for the user to interactively accept/reject suggested changes to the text:

>>> text = "The birds flevv down\n south, but wefe quickly apprehended\n by border patrol agents"
>>> spellcheck(text, interactive = "T").fix()
Suggestion 1

Each suggestion provides the local context around the garbled text, so that the user can determine if the suggestion fits.

Suggestion 2
>>> ### User accepts change to "flevv", but rejects change to "wefe" in GUI
'The birds flew down\n south, but wefe quickly apprehended\n by border patrol agents'

This returns the text with all accepted changes reflected. All rejected suggestions are left as-is in the text.

Command-Line

OCRfixr is also callable via command-line (intended for Guiguts use):

>>> ocrfixr input_text.txt output_filename.txt

The output file will list the line number and position of all suggested changes.

Avoiding "Damn You, Autocorrect!"

By design, OCRfixr is change-averse:

  • If spellcheck/context do not line up, no update is made.
  • Likewise, if there is >1 word that lines up for spellcheck/context, no update is made.
  • Only the top 15 context suggestions are considered, to limit low-probability matches.
  • If the suggestion is a homophone of the original word, it is ignored (original: coupla --> suggestion: couple). These are assumed to be 'stylistic' or phonetic misspellings
  • Proper nouns (anything starting with a capital letter) are not evaluated for spelling.

Word context is drawn from all sentences in the current paragraph (designated by a '\n'), to maximize available information, while also not bogging down the BERT model.

Credits

  • symspellpy powers spellcheck suggestions
  • transformers does the heavy lifting for BERT context modelling
  • DataMunging provided a very useful list of common scanning errors
  • SCOWL word list is Copyright 2000-2019 by Kevin Atkinson.
  • This project was created to help Distributed Proofreaders. Support them here: https://www.pgdp.net/c/

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

OCRfixr-1.5.1.tar.gz (438.4 kB view details)

Uploaded Source

Built Distribution

OCRfixr-1.5.1-py3-none-any.whl (437.4 kB view details)

Uploaded Python 3

File details

Details for the file OCRfixr-1.5.1.tar.gz.

File metadata

  • Download URL: OCRfixr-1.5.1.tar.gz
  • Upload date:
  • Size: 438.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/62.3.2 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.9.13

File hashes

Hashes for OCRfixr-1.5.1.tar.gz
Algorithm Hash digest
SHA256 acb0a2ded5c837bc26be5ab7b20438cf0e188155ba8b167d25a39664875e1131
MD5 cc06df89a3dc64689057818e394491b1
BLAKE2b-256 5aee40f5fcb864530ebecb7393e59db95aea92ac187730ff478cf7b23a35f390

See more details on using hashes here.

File details

Details for the file OCRfixr-1.5.1-py3-none-any.whl.

File metadata

  • Download URL: OCRfixr-1.5.1-py3-none-any.whl
  • Upload date:
  • Size: 437.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.3.0 pkginfo/1.6.1 requests/2.25.1 setuptools/62.3.2 requests-toolbelt/0.9.1 tqdm/4.55.0 CPython/3.9.13

File hashes

Hashes for OCRfixr-1.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 94681cfb363910a0703a12601c0c6c21ffaabe32c6f4edd887993d5966003a51
MD5 670f8424c85d351cfd702e5b2917e741
BLAKE2b-256 0da80cca3e33942db80a5d5d68090b69fa68dd7ebf3ce5b7cac5c49a6ca7f747

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page