Skip to content

collectionslabs/pyes

 
 

Repository files navigation

pyes - Python ElasticSearch

Web:http://pypi.python.org/pypi/pyes/
Download:http://pypi.python.org/pypi/pyes/
Source:http://github.com/aparo/pyes/
Documentation:http://pyes.rtfd.org/
Keywords:search, elastisearch, distribute search

--

pyes is a connector to use elasticsearch from python.

This version requires elasticsearch 0.15 or above.

Features

  • Thrift/HTTP protocols
  • Bulk insert/delete
  • Index management
  • Every search query types
  • Facet Support
  • Geolocalization support
  • Highlighting
  • Percolator
  • River support

Changelog

  1. 0.19.1:

    Renamed field_name in name in ScriptFields

    Fixed ResultSet slicing.

    Create Manager to manage API action grouped as Elasticsearch.

    Moved tests outside pyes code dir. Update references. Upgraded test elasticsearch to 0.19.9.

    Added documentation links

    Got docs building on readthedocs.org (Wraithan - Chris McDonald)

    Renamed scroll_timeout in scroll

    Moved FacetFactory include

    Renamed field_name in name in ScriptFields

    Using only thrift_connect to manage thrift existence

    Added model and scan to query

    Added exists document call

    Added routing to delete

    Removed minimum_number_should_match parameter.It is not supported by elastic search and causes errors when using a BoolFilter. (Jernej Kos)

    Improved speed json conversion of datetime values

    Add boost argument to TextQuery

    Added boost argument to TextQuery. (Jernej Kos)

    Go back to urllib3 instead of requests. (gsakkis)

    Enhance Twitter River class. (thanks @dendright)

    Add OAuth authentication and filtering abilities to Twitter River. (Jack Riches)

    HasChildFilter expects a Query. (gsakkis)

    Fixed _parent being pulled from _meta rather than the instance itself. (merrellb)

    Add support of all_terms to TermFacet. (mouad)

TODO

  • add ORM to manage objects
  • much more documentation
  • add coverage
  • add jython native client protocol

Contributing and Testing

To develop and contribute to pyes, clone this repository, then run pip install -r requirements_develop.txt In order to run the tests, make sure you first install the following elasticsearch plugins

attachment:https://github.com/elasticsearch/elasticsearch-mapper-attachments
lang-js:https://github.com/elasticsearch/elasticsearch-lang-javascript (1.2.0)
lang-python:https://github.com/elasticsearch/elasticsearch-lang-python (1.1.0)

NODE: Be particularly careful about the version of the plugin you are installing. It must match the correct version of elasticsearch you have installed. Installing a wrong version of the plugin could cause unexpected errors that are extremely hard to debug. When in doubt, run elasticsearch in foreground mode for easier exception trance and debugging.

To actually run the tests, run nosetests from the root directory of the repo. Before and after you branch and add your changes, make sure all the tests pass. Please also add test cases for each feature you add and document the necessary environment requirements to run the test case.

License

This software is licensed under the New BSD License. See the LICENSE file in the top distribution directory for the full license text.

About

Python connector for ElasticSearch

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 99.8%
  • Shell 0.2%