Skip to main content

Fast Python phonetic algorithms

Project description

https://img.shields.io/pypi/v/Fuzzy.svg https://img.shields.io/pypi/pyversions/Fuzzy.svg https://img.shields.io/travis/yougov/fuzzy/master.svg

Fuzzy is a python library implementing common phonetic algorithms quickly. Typically this is in string similarity exercises, but they’re pretty versatile.

It uses C Extensions (via Cython) for speed.

The algorithms are:

Usage

The functions are quite easy to use!

>>> import fuzzy
>>> soundex = fuzzy.Soundex(4)
>>> soundex('fuzzy')
'F200'
>>> dmeta = fuzzy.DMetaphone()
>>> dmeta('fuzzy')
['FS', None]
>>> fuzzy.nysiis('fuzzy')
'FASY'

Performance

Fuzzy’s Double Metaphone was ~10 times faster than the pure python implementation by Andrew Collins in some recent testing. Soundex and NYSIIS should be similarly faster. Using iPython’s timeit:

In [3]: timeit soundex('fuzzy')
1000000 loops, best of 3: 326 ns per loop

In [4]: timeit dmeta('fuzzy')
100000 loops, best of 3: 2.18 us per loop

In [5]: timeit fuzzy.nysiis('fuzzy')
100000 loops, best of 3: 13.7 us per loop

Distance Metrics

We recommend the Python-Levenshtein module for fast, C based string distance/similarity metrics. Among others functions it includes:

In testing it’s been several times faster than comparable pure python implementations of those algorithms.

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

Fuzzy-1.2.2.tar.gz (14.8 kB view details)

Uploaded Source

File details

Details for the file Fuzzy-1.2.2.tar.gz.

File metadata

  • Download URL: Fuzzy-1.2.2.tar.gz
  • Upload date:
  • Size: 14.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for Fuzzy-1.2.2.tar.gz
Algorithm Hash digest
SHA256 6b240e630235f183730b27fcb70fdd0d409bee2c3a4e7a964eeae093a28c4f38
MD5 300a8fc0542000c96009d82481d0bd67
BLAKE2b-256 adb0210f790e81e3c9f86a740f5384c758ad6c7bc1958332cf64263a9d3cf336

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