![]() |
VOOZH | about |
dotnet add package XSoundex --version 1.0.0
NuGet\Install-Package XSoundex -Version 1.0.0
<PackageReference Include="XSoundex" Version="1.0.0" />
<PackageVersion Include="XSoundex" Version="1.0.0" />Directory.Packages.props
<PackageReference Include="XSoundex" />Project file
paket add XSoundex --version 1.0.0
#r "nuget: XSoundex, 1.0.0"
#:package XSoundex@1.0.0
#addin nuget:?package=XSoundex&version=1.0.0Install as a Cake Addin
#tool nuget:?package=XSoundex&version=1.0.0Install as a Cake Tool
Soundex is a phonetic algorithm for indexing names by sound, as pronounced in English. The goal is for homophones to be encoded to the same representation so that they can be matched despite minor differences in spelling. The algorithm mainly encodes consonants; a vowel will not be encoded unless it is the first letter. Soundex is the most widely known of all phonetic algorithms (in part because it is a standard feature of popular database software such as IBM Db2, PostgreSQL, MySQL, SQLite, Ingres, MS SQL Server,Oracle. and SAP ASE.) Improvements to Soundex are the basis for many modern phonetic algorithms. Source
Xsoundex is small .Net library to make usage of this algorithm simpler. The Good Part of this library is that it's language agnostic and with add a new and small changes (like adding a small resource) you can have it in your language! The result can use the default culture of system, or you provide it explicitly!
See the Demo in multilanguage (English and Persian) HERE
No need for any DI! Just add the nuget package to your project!
"Hussein".ToSoundex() // uses the current culture of system
"Hussein".ToSoundex("en-US") // explictly tell the culture
SELECT SOUNDEX("Hussein") // Give you the soundex in your Database
You can generate your result in memory on the back-end, or get the result in SQL Server and compare it in your application.
lists.Where(x => x.Key == text.ToSoundex())
OR
"Hussein".HasTheSameSoundex("Hossein")
AND
"Hussein".HasTheSameSoundex("Hossein","en-US")
This Algorithm is based on the original algorithm and can be so much better, so:
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net7.0 net7.0 is compatible. net7.0-android net7.0-android was computed. net7.0-ios net7.0-ios was computed. net7.0-maccatalyst net7.0-maccatalyst was computed. net7.0-macos net7.0-macos was computed. net7.0-tvos net7.0-tvos was computed. net7.0-windows net7.0-windows was computed. net8.0 net8.0 was computed. net8.0-android net8.0-android was computed. net8.0-browser net8.0-browser was computed. net8.0-ios net8.0-ios was computed. net8.0-maccatalyst net8.0-maccatalyst was computed. net8.0-macos net8.0-macos was computed. net8.0-tvos net8.0-tvos was computed. net8.0-windows net8.0-windows was computed. net9.0 net9.0 was computed. net9.0-android net9.0-android was computed. net9.0-browser net9.0-browser was computed. net9.0-ios net9.0-ios was computed. net9.0-maccatalyst net9.0-maccatalyst was computed. net9.0-macos net9.0-macos was computed. net9.0-tvos net9.0-tvos was computed. net9.0-windows net9.0-windows was computed. net10.0 net10.0 was computed. net10.0-android net10.0-android was computed. net10.0-browser net10.0-browser was computed. net10.0-ios net10.0-ios was computed. net10.0-maccatalyst net10.0-maccatalyst was computed. net10.0-macos net10.0-macos was computed. net10.0-tvos net10.0-tvos was computed. net10.0-windows net10.0-windows was computed. |
Showing the top 1 NuGet packages that depend on XSoundex:
| Package | Downloads |
|---|---|
|
FluentSimilarity
FluentSimilarity: A flexible and fluent API for comparing object properties, supporting string, numeric, and date-based similarity calculations with customizable rules. |
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 1.0.0 | 65,887 | 1/3/2023 |