ElasticSearch Handler
Project description
exec_es
exec_es 对ElasticSearch进行了二次开发,针对多开发环境数据写入,以及bulk进行了优化。
Installation
1.使用python包管理工具 pip 进行安装。
pip install exec-es
Usage
from execelasticsearch import ExecES, ClientConfig, MappingMethod
# MappingData.SearchBody.update will change defult Search Body Template, use before ExecES init.
MappingMethod.SearchBody.update('match', 'match', {"<<field>>": {"query": "<<value>>"}})
dt_config = ClientConfig(hosts=[{'host': "172.28.0.1"}])
dp_config = ClientConfig(hosts=[{'host': "172.28.0.2"}], doc_type='your_tags')
es_clients = ExecES(dt=dt_config, dp=dp_config)
index = 'exec_es_test'
hosts = ["dt", "dp"]
def es_create(data_, dex=0):
data_ = data_[dex]
print(es_clients.create(index, data_['id'], data_, hosts))
def es_update(data_, dex=0):
data_ = data_[dex]
data_['account_score'] = 10
print(es_clients.update(index, data_['id'], data_, hosts))
def es_delete(id_):
print(es_clients.delete(index, id_, hosts))
def es_update_or_ignore(data_, dex=0):
data_ = data_[dex]
print(es_clients.update_or_ignore(index, data_['id'], data_, hosts))
def es_upsert(data_, dex=0):
data_ = data_[dex]
print(es_clients.upsert(index, data_['id'], data_, hosts))
def es_bulk_upsert(data_):
data_[0]['account_score'] = 10
print(es_clients.bulk_upsert(index, data_, hosts))
def es_bulk_delete(data_):
ids = [i['id'] for i in data_]
print(es_clients.bulk_delete(index, ids, hosts))
def es_mget(data_, _source_includes=None):
ids = [i['id'] for i in data_]
print(es_clients.mget(index, ids, hosts, _source_includes=_source_includes))
def es_exists(ids: list):
print(es_clients.exists_ids(index, ids, hosts))
search_b = es_clients.search_body
search_b.update(body_type1={"query": {"bool": {"must": {"exists": {"field": "<<field>>"}}}}})
search_b["body_type2"] = {"query": {"bool": {"must": {"exists": {"field": "<<field>>"}}}}}
print(search_b.body_type_list) # show default body_type list
def es_search(body_kwargs: dict = None):
res = es_clients.search(index, body_kwargs or {'match': dict(field='id', value=1)}, 'dt')
for i in res:
print(i)
def es_original_func():
print(es_clients['dt'].ping())
if __name__ == '__main__':
es_original_func()
Contributing
使用前请做适当的测试,以确定跟您的项目完全兼容。
License
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
exec-es-0.0.9.tar.gz
(8.7 kB
view details)
Built Distribution
File details
Details for the file exec-es-0.0.9.tar.gz
.
File metadata
- Download URL: exec-es-0.0.9.tar.gz
- Upload date:
- Size: 8.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | eed5a73f3569f477a6dafba27548d20be912bda6b1849c05214440982a73649c |
|
MD5 | e48458e6a73950113fe7cf16bb3e955c |
|
BLAKE2b-256 | a09b91ce8adc99c30bf808e02f41718877ceb228ea6516315d10373c59c81faf |
File details
Details for the file exec_es-0.0.9-py3-none-any.whl
.
File metadata
- Download URL: exec_es-0.0.9-py3-none-any.whl
- Upload date:
- Size: 6.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.10.1
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c097f63606727863b58a3c00cd6d6f9b0da31742aa74101e4f843bf3d3cb0806 |
|
MD5 | e70d10964173dc35f0cad9e710e1acb1 |
|
BLAKE2b-256 | dbede0611c085e53974f6def951ad06328010ef61bbbbab2ab5f913044ea6d78 |