Skip to main content

Show character-level differences between two strings with colored terminal output

Project description

philiprehberger-diff-strings

Tests PyPI version License

Show character-level differences between two strings with colored terminal output.

Install

pip install philiprehberger-diff-strings

Usage

from philiprehberger_diff_strings import diff

print(diff("hello world", "hello there"))

Character-level diff

from philiprehberger_diff_strings import diff

# Colored output (default)
print(diff("the cat sat", "the bat sat"))

# Plain text output
print(diff("the cat sat", "the bat sat", color=False))

Programmatic diff

from philiprehberger_diff_strings import char_diff

changes = char_diff("abc", "adc")
# [Match(text='a'), Replace(old='b', new='d'), Match(text='c')]

Word-level diff

from philiprehberger_diff_strings import word_diff

print(word_diff("the quick brown fox", "the slow brown dog", color=False))

Line-level diff

from philiprehberger_diff_strings import line_diff

a = "line one\nline two\nline three"
b = "line one\nline 2\nline three"
print(line_diff(a, b, color=False))
# Shows unified-diff style output with +/- markers

# Control context lines shown around changes
print(line_diff(a, b, context=1))

Diff summary

from philiprehberger_diff_strings import diff_summary

summary = diff_summary("hello world", "hello there")
print(summary.additions)   # number of insertions
print(summary.deletions)   # number of deletions
print(summary.changes)     # number of replacements
print(summary.similarity)  # similarity ratio (0.0 to 1.0)

HTML diff

from philiprehberger_diff_strings import html_diff

result = html_diff("the cat", "the bat")
# 'the <del>c</del><ins>b</ins>at'

Custom colors

from philiprehberger_diff_strings import diff, word_diff

# Use custom ANSI colors (red, green, yellow, blue, magenta, cyan)
print(diff("abc", "adc", insert_color="cyan", delete_color="magenta", replace_color="blue"))
print(word_diff("old text", "new text", insert_color="blue", replace_color="cyan"))

Patch (reconstruct from changes)

from philiprehberger_diff_strings import char_diff, patch

changes = char_diff("hello world", "hello there")
result = patch("hello world", changes)
assert result == "hello there"

Similarity ratio

from philiprehberger_diff_strings import similarity

score = similarity("hello", "hallo")  # 0.8

Test assertions

from philiprehberger_diff_strings import assert_strings_equal

assert_strings_equal("expected output", "expected output")  # passes
assert_strings_equal("expected", "actual")  # raises AssertionError with diff

API

Function Description
diff(a, b, *, color=True, insert_color="green", delete_color="red", replace_color="yellow") Character-level diff as a string
char_diff(a, b) Programmatic diff returning a list of Change objects
word_diff(a, b, *, color=True, insert_color="green", delete_color="red", replace_color="yellow") Word-level diff as a string
line_diff(a, b, *, color=True, context=3) Unified-style line-level diff
diff_summary(a, b) Summary with addition/deletion/change counts and similarity
html_diff(a, b) Character-level diff as HTML with <ins>/<del> tags
patch(original, changes) Reconstruct the modified string from a change list
similarity(a, b) Similarity ratio between 0.0 and 1.0
assert_strings_equal(expected, actual, *, msg="") Assert equal or raise with diff

Change types

Type Fields Description
Match(text) text: str Unchanged text
Insert(text) text: str Text added in the second string
Delete(text) text: str Text removed from the first string
Replace(old, new) old: str, new: str Text that changed between strings

DiffSummary

Field Type Description
additions int Number of insertion operations
deletions int Number of deletion operations
changes int Number of replacement operations
similarity float Similarity ratio between 0.0 and 1.0

Development

pip install -e .
python -m pytest tests/ -v

License

MIT

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

philiprehberger_diff_strings-0.2.0.tar.gz (6.4 kB view details)

Uploaded Source

Built Distribution

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

philiprehberger_diff_strings-0.2.0-py3-none-any.whl (6.7 kB view details)

Uploaded Python 3

File details

Details for the file philiprehberger_diff_strings-0.2.0.tar.gz.

File metadata

File hashes

Hashes for philiprehberger_diff_strings-0.2.0.tar.gz
Algorithm Hash digest
SHA256 c0f7e0dff575066773c69c5aeb407406b45ea902b317d42b6049f4eab4457161
MD5 290e5faafaf825e1860eff49e79fbf77
BLAKE2b-256 0104a9dc5267d8f239efa68af24da462c705b582f670a73d19825dfbe47f97e5

See more details on using hashes here.

File details

Details for the file philiprehberger_diff_strings-0.2.0-py3-none-any.whl.

File metadata

File hashes

Hashes for philiprehberger_diff_strings-0.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 5b831bdf528879b7f32b05a91b02079c2380c84f51639b6f3abbd3f023925763
MD5 1f53b2546612fc243f33783b698932ae
BLAKE2b-256 4ecd653d7ff7d1f0acb14ff2d5293fdae07d6966176377ebeb9909a7f68356aa

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