Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/voku/phonetic-algorithms
Phonetic-Algorithms for fuzzy searching | PHP
https://github.com/voku/phonetic-algorithms
algorithm fuzzy-search homophone metaphone phonetic php
Last synced: 3 months ago
JSON representation
Phonetic-Algorithms for fuzzy searching | PHP
- Host: GitHub
- URL: https://github.com/voku/phonetic-algorithms
- Owner: voku
- License: mit
- Created: 2017-03-26T22:38:52.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2023-12-15T02:26:27.000Z (about 1 year ago)
- Last Synced: 2024-10-29T22:48:13.012Z (3 months ago)
- Topics: algorithm, fuzzy-search, homophone, metaphone, phonetic, php
- Language: PHP
- Homepage:
- Size: 67.4 KB
- Stars: 17
- Watchers: 4
- Forks: 8
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: .github/CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
README
[![Build Status](https://github.com/voku/phonetic-algorithms/actions/workflows/ci.yml/badge.svg?branch=master)](https://github.com/voku/phonetic-algorithms/actions)
[![Coverage Status](https://coveralls.io/repos/github/voku/phonetic-algorithms/badge.svg?branch=master)](https://coveralls.io/github/voku/phonetic-algorithms?branch=master)
[![Latest Stable Version](https://poser.pugx.org/voku/phonetic-algorithms/v/stable)](https://packagist.org/packages/voku/phonetic-algorithms)
[![Total Downloads](https://poser.pugx.org/voku/phonetic-algorithms/downloads)](https://packagist.org/packages/voku/phonetic-algorithms)
[![Latest Unstable Version](https://poser.pugx.org/voku/phonetic-algorithms/v/unstable)](https://packagist.org/packages/voku/phonetic-algorithms)
[![License](https://poser.pugx.org/voku/phonetic-algorithms/license)](https://packagist.org/packages/voku/phonetic-algorithms)# Phonetic-Algorithms
## Description
- "PhoneticGerman"-Class:
A phonetic algorithms for the german language via "Kölner Phonetik": [en.wikipedia.org/wiki/Cologne_phonetics](https://en.wikipedia.org/wiki/Cologne_phonetics)
- "PhoneticEnglish"-Class:
A phonetic algorithms for the english language via "metaphone": [en.wikipedia.org/wiki/Metaphone](https://en.wikipedia.org/wiki/Metaphone)
- "PhoneticFrench"-Class:
A phonetic algorithms for the french language via "SOUNDEX FR": [www.roudoudou.com/phonetic.php](http://www.roudoudou.com/phonetic.php)
* [Installation](#installation)
* [Usage](#usage)
* [History](#history)## Installation
1. Install and use [composer](https://getcomposer.org/doc/00-intro.md) in your project.
2. Require this package via composer:```sh
composer require voku/phonetic-algorithms
```## Usage
You the "phonetic_word"-method if you need a fuzzy-search for single words e.g. last-names or product-names.
```php
use voku\helper\Phonetic;$words = array(
'Moelleken',
'Mölleken',
'Möleken',
'Moeleken',
'Moellecken',
'Möllecken',
'Mölecken',
);
$phonetic = new Phonetic('de');
foreach ($words as $word) {
$phonetic->phonetic_word($string); // '6546'
}
```You can use the "phonetic_sentence"-method to process sentences.
```php
use voku\helper\Phonetic;$string = 'Ein Satz mit vielen Wortern';
$phonetic = new Phonetic('de');
$phonetic->phonetic_sentence($string, (bool) false, (false|int) false);// [
// 'Ein' => '06',
// 'Satz' => '8',
// 'mit' => '62',
// 'vielen' => '356',
// 'Wortern' => '37276'
// ]
```You can use the "phonetic_matches"-method to search for words in an array of words.
```php
use voku\helper\Phonetic;$phonetic = new Phonetic('de');
$tests = array(
'Moelleken', // '6546',
'Mölleken', // '6546',
'Möleken', // '6546',
'Moeleken', // '6546',
'oder', // '027',
'was', // '38',
'Moellecken', // '6546',
'Möllecken', // '6546',
'Mölecken', // '6546',
);$phonetic->phonetic_matches('Moelleken', $tests);
// [
// 'Moelleken' => 'Moelleken',
// 'Mölleken' => 'Moelleken',
// 'Möleken' => 'Moelleken',
// 'Moeleken' => 'Moelleken',
// 'Moellecken' => 'Moelleken',
// 'Möllecken' => 'Moelleken',
// 'Mölecken' => 'Moelleken',
// ]
```## History
See [CHANGELOG](CHANGELOG.md) for the full history of changes.