mapado / simstring-bundle
Mapado Simstring Bundle: Record search
Installs: 2 211
Dependents: 0
Suggesters: 0
Security: 0
Stars: 3
Watchers: 14
Forks: 2
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=5.3.3
- symfony/config: ~2.3
- symfony/console: ~2.3
- symfony/dependency-injection: ~2.3
- symfony/framework-bundle: ~2.3
- symfony/http-kernel: ~2.3
Requires (Dev)
- atoum/atoum: dev-master@dev
- raulfraile/ladybug-bundle: ~0.7
README
Mapado SimstringBundle : Symfony bundle for simstring record search
Installation
This extension use Simstring. You can find a description of how we use it on mapado.com on our blog.
You have to install Simsting PHP Extension to make this bundle working.
Get the bundle
Add this in your composer.json
{ "require": { "mapado/simstring-bundle": "1.*" } }
and then run
php composer.phar update
or
composer update
if you installed composer globally.
Add the classes to your kernel
// app/AppKernel.php public function registerBundles() { $bundles = array( // ... new Mapado\SimstringBundle\MapadoSimstringBundle(), ); }
Configuration
Declare your databases
# app/config/config.yml mapado_simstring: databases: city: "path/to/your/database/city.db" country: "path/to/your/database/country.db"
Declare your readers
# app/config/config.yml mapado_simstring: databases: city: "path/to/your/database/city.db" country: "path/to/your/database/country.db" reader: city_cosine: database: city measure: cosine # values are cosine/dice/jaccard/overlap/exact threshold: 0.7 # float between 0 and 1 min_results: 1 # minimim number of results if you have a lower threshold limit # you can add as many reader you like
Declare your writers
# app/config/config.yml mapado_simstring: databases: city: "path/to/your/database/city.db" country: "path/to/your/database/country.db" reader: city: database: city measure: cosine # values are cosine/dice/jaccard/overlap/exact (default is: exact) threshold: 0.7 # float between 0 and 1 min_results: 1 # minimim number of results if you have a lower threshold limit # you can add as many reader you like writer: city: database: city unicode: false # not required ngram: 3 # not required be: false # not required
Link with Doctrine ORM
SimstringBundle is compatible with Doctrine ORM. You only add a few database settings to get objects from your database.
# app/config/config.yml mapado_simstring: databases: city: path: "path/to/your/database/city.db" persistence: driver: orm # only ORM is supported for the moment model: \Mapado\MyEntityBundle\Entity\City # required field: simstringColumn # required options: # optional manager: geolocation # if not set, the default manager will be used repository_method: findVisibleBy # findBy is used by default
Usage
You can now use the functions in your controllers or via command line
Command Line
# Perform the query php app/console mapado:simstring:search city cihcago # will output chicago # Perform an insert php app/console mapado:simstring:insert city chicago houson boston montréal # will rewrite the database with this cities
Controller
// Perform the query $resultList = $this->get('mapado.simstring.city_reader')->find('New Yrok'); // Dynamically change the threshold $resultList = $this->get('mapado.simstring.city_reader')->find('New Yrok', 0.3);
$resultList
will be an iterator of SimstringResult
having a string (or an Entity if you used the ORM mapper) as value.