forked from od-eon/django-fts-odeon
-
Notifications
You must be signed in to change notification settings - Fork 3
Django interface to postgresql's full-text search functionality
License
odeoncg/django-fts-odeon
Folders and files
Name | Name | Last commit message | Last commit date | |
---|---|---|---|---|
Repository files navigation
django-fts-odeon is a fork of django-fts ( http://code.google.com/p/django-fts/ ) The only supported back-end is PostgreSQL Dependencies: - Django - PostgreSQL - South ( http://south.aeracode.org/ ) Install: - add "FTS_BACKEND = 'pgsql://' " in settings.py and "fts" to INSTALLED_APPS Usage: - subclass your model from fts.SearchableModel - create a custom manager with the list of fields that should be indexed (CharField and TextField only) class Blog(fts.SearchableModel): title = models.CharField(max_length=100) body = models.TextField() search_objects = fts.SearchManager(fields=('title', 'body')) # index both fields - create FTS indices with ./manage.py create_fts_indices - if you need to update by hand all the search indices for some reason, you can do "./manage.py update_fts_indices". Normally, the indices are always up to date because postgres takes care of them on each insert/update/delete. - getting the results ordered by rank in postgres (the rank field's name is not important. Just avoid any clashes with existing fields): Blog.search_objects.search('foo bar', rank_field='rank') - highlighting results (highlight_field is the actual model field where you want the highlighting done. The modified text will be placed in a new field called highlight_field+'_highlight'): for blog in Blog.search_objects.search('foo bar', highlight_field='body'): print blog.body_highlight - see fts_test/tests.py for more examples website: http://od-eon.com/labs/django-fts-odeon/ contact: [email protected]
About
Django interface to postgresql's full-text search functionality
Resources
License
Stars
Watchers
Forks
Releases
No releases published
Packages 0
No packages published
Languages
- Python 100.0%