Skip to main content

Computing edit distance on arbitrary Python sequences

Project description

edit_distance

build PyPI version codecov

Python module for computing edit distances and alignments between sequences.

I needed a way to compute edit distances between sequences in Python. I wasn't able to find any appropriate libraries that do this so I wrote my own. There appear to be numerous edit distance libraries available for computing edit distances between two strings, but not between two sequences.

This is written entirely in Python. This implementation could likely be optimized to be faster within Python. And could probably be much faster if implemented in C.

The library API is modeled after difflib.SequenceMatcher. This is very similar to difflib, except that this module computes edit distance (Levenshtein distance) rather than the Ratcliff and Oberhelp method that Python's difflib uses. difflib "does not yield minimal edit sequences, but does tend to yield matches that 'look right' to people."

If you find this library useful or have any suggestions, please send me a message.

Installing & uninstalling

The easiest way to install is using pip:

pip install edit_distance

To uninstall with pip:

pip uninstall edit_distance

This requires Python 3.9 or later.

API usage

To see examples of usage, view the difflib documentation. Additional API-level documentation is available on ReadTheDocs

Example API usage:

import edit_distance
ref = ["hi", "there", "how", "are", "you"]
hyp = ["hi", "here", "how", "are", "you", "doing"]
sm = edit_distance.SequenceMatcher(a=ref, b=hyp)

sm.distance()
# 2
sm.get_opcodes()
# [['equal', 0, 1, 0, 1], ['replace', 1, 2, 1, 2], ['equal', 2, 3, 2, 3], ['equal', 3, 4, 3, 4], ['equal', 4, 5, 4, 5], ['insert', 5, 5, 5, 6]]
list(sm.get_matching_blocks())
# [[0, 0, 1], [2, 2, 1], [3, 3, 1], [4, 4, 1]]
sm.ratio()
# 0.7272727272727273

Command line usage

Installing the package also installs an edit-distance command, which compares two files line by line and prints the edit distance between each pair of lines:

edit-distance file1.txt file2.txt

Differences from difflib

In addition to the SequenceMatcher methods, distance() and matches() methods are provided which compute the edit distance and the number of matches.

sm.distance()
sm.matches()

Even if the alignment of the two sequences is identical to difflib, get_opcodes() and get_matching_blocks() may return slightly different sequences. The opcodes returned by this library represent individual character operations, and thus should never span two or more characters.

It's also possible to compute the maximum number of matches rather than the minimum number of edits:

sm = edit_distance.SequenceMatcher(a=ref, b=hyp, 
     action_function=edit_distance.highest_match_action)

Notes

This doesn't implement the 'junk' matching features in difflib.

Hacking

To run unit tests:

python -m unittest

To deploy...

Contributing and code of conduct

For contributions, it's best to Github issues and pull requests. Proper testing and documentation required.

Code of conduct is expected to be reasonable, especially as specified by the Contributor Covenant

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

edit_distance-1.0.9.tar.gz (10.0 kB view details)

Uploaded Source

Built Distribution

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

edit_distance-1.0.9-py3-none-any.whl (11.4 kB view details)

Uploaded Python 3

File details

Details for the file edit_distance-1.0.9.tar.gz.

File metadata

  • Download URL: edit_distance-1.0.9.tar.gz
  • Upload date:
  • Size: 10.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for edit_distance-1.0.9.tar.gz
Algorithm Hash digest
SHA256 074c29ec00c8e74ff2627759cf3d40aa2d95cd24a0cde4acc62c820df9f3af26
MD5 ac454b9b988f8d8d1e97f397c4e58a12
BLAKE2b-256 6038f5ceab4c9dfa045827921138d5c0b5a6411d7b29ebd4011b0364f7724b2e

See more details on using hashes here.

File details

Details for the file edit_distance-1.0.9-py3-none-any.whl.

File metadata

  • Download URL: edit_distance-1.0.9-py3-none-any.whl
  • Upload date:
  • Size: 11.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for edit_distance-1.0.9-py3-none-any.whl
Algorithm Hash digest
SHA256 6b3e95263b548e335c4982486afad31a17f79b6d2f48c3d1e7a37a5dfc1838f9
MD5 cd9206877cf0b75637f58408c3a76d98
BLAKE2b-256 5308a6c994306096eb15ad398def16ffe87df68314599b9f82f3235770c21095

See more details on using hashes here.

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