Skip to main content

An easy-to-use Elasticsearch BM25 interface

Project description

Easy Elasticsearch

This repository contains a high-level encapsulation for using Elasticsearch with python in just a few lines.

Installation

Via pip:

pip install easy-elasticsearch

Via git repo:

git clone https://github.com/kwang2049/easy-elasticsearch
pip install -e . 

Usage

To utilize the elasticsearch service, one can either start an ES service manually and then indicate the host and port_http; or leave host=None by default to start a docker container itself. Finally, just either call its rank or score function for retrieval or calculating BM25 scores.

from easy_elasticsearch import ElasticSearchBM25

pool = {
    'id1': 'What is Python? Is it a programming language',
    'id2': 'Which Python version is the best?',
    'id3': 'Using easy-elasticsearch in Python is really convenient!'
}
bm25 = ElasticSearchBM25(pool, port_http='9222', port_tcp='9333')  # By default, when `host=None`, a ES docker container will be started at localhost.

query = "What is Python?"
rank = bm25.query(query, topk=10)  # topk should be <= 10000
scores = bm25.score(query, document_ids=['id2', 'id3'])

print(query, rank, scores)
bm25.delete_index()  # delete the one-trial index named 'one_trial'
bm25.delete_container()  # remove the docker container'

Another example for retrieving Quora questions can be found in example/quora.py:

python -m easy_elasticsearch.examples.quora

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

easy-elasticsearch-0.0.4.tar.gz (4.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

easy_elasticsearch-0.0.4-py3-none-any.whl (9.4 kB view details)

Uploaded Python 3

File details

Details for the file easy-elasticsearch-0.0.4.tar.gz.

File metadata

  • Download URL: easy-elasticsearch-0.0.4.tar.gz
  • Upload date:
  • Size: 4.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.6.13

File hashes

Hashes for easy-elasticsearch-0.0.4.tar.gz
Algorithm Hash digest
SHA256 43384354bf1853572c9c9a28e3e2a9903521ffa9cb4d69afbcd3ffe75a1a8384
MD5 8923dd5be31d00ba5e917af8aac92185
BLAKE2b-256 8d5fd5a7f98da92513aa742f4831380ab90746cbe3dda5d6abe11cdb823213ad

See more details on using hashes here.

File details

Details for the file easy_elasticsearch-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: easy_elasticsearch-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 9.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.2 importlib_metadata/4.6.1 pkginfo/1.7.1 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.6.13

File hashes

Hashes for easy_elasticsearch-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 0ed4ffeeff298d94dfb42e6b864c18c70a463101529dc8e493f924496990586c
MD5 6d854ddbddfdbc0031cc464c60e99e84
BLAKE2b-256 b38cf0a22c7957f68015fcf5511d5ec60d7a2a09b5ef958af9575b0a54c79645

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page