Flexible integration of Elasticsearch into Python projects.
Printen is the a simple, flexible module for integrating Elasticsearch into Python projects - especially projects utilizing Peewee or Django models.
Printen’s code is currently in active development and should be considered alpha - breaking changes should be expected.
There is no shortage of fine search libraries for Python. The common tool used is [Haystack](http://haystacksearch.org/), though this is oriented specifically towards Django, but supports a multitude of search backends. This is a great choice if you need flexibility in your search backends, but one can begin to feel constrained as the interface to the search backend is necessarily generic, so as to support all search backends similarly.
Other options include [django-simple-elasticsearch](https://github.com/jaddison/django-simple-elasticsearch), which has the advantage of specifically focusing on Elasticsearch, but is limited to Django and isn’t under active development.
A final option is to use the excellent official [Python Elasticsearch Client](http://elasticsearch-py.readthedocs.org/en/master/index.html), which is not super hard, but does require a decent amount of work to map it to the concepts of your ORM.
Printen seeks to do this work for you, without being overly choosy about what Python framework you use it with (essentially the opposite of Haystack - choosy about the search engine, not choosy about the Python framework).
Printen is expected to be compatible with Elasticsearch 2.0 and above.
To see the complete documentation, visit Printen’s documentation on [Read The Docs](http://printen.readthedocs.org/).
Printen can still be intalled via pip:
$ pip install printen
or if you have the source locally:
$ python setup.py install
Printen is licensed under the [BSD License](LICENSE.md)
This was inspired by [James Addison’s](https://github.com/jaddison) [django-simple-elasticsearch](https://github.com/jaddison/django-simple-elasticsearch).
__0.0.1 (2016-11-02)__: Initial Release of code to GitHub __0.0.2 (2016-22-03)__: Fix for when no existing aliases exist __0.0.4 (2016-22-03)__: Initial PyPi Release __0.0.5 (2016-23-03)__: Fix issue with missing dependencies on pip install __0.0.6 (2017-01-03)__: Remove pypandoc dependency. __0.0.7 (2017-01-03)__: Python packaging - a hot mess.
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.