0

Comment puis-je obtenir le résultat d'une agrégation?Comment obtenir aggs dans elasticsearch-dsl-py

Mon code est:

s = Items.search() #Items is DSL class 
s.aggs.bucket('SP', 'terms', item=item_name).metric('max_amt', 'max', field='amount') 
res = s.execute() 

Lorsque vous essayez cela, je reçois l'erreur suivante:

ERROR:django.request:Internal Server Error: /items/ 
Traceback (most recent call last): 
    File "/usr/local/lib/python2.7/dist-packages/django/core/handlers/base.py", line 149, in get_response 
    response = self.process_exception_by_middleware(e, request) 
    File "/usr/local/lib/python2.7/dist-packages/django/core/handlers/base.py", line 147, in get_response 
    response = wrapped_callback(request, *callback_args, **callback_kwargs) 
    File "/home/shipra/codeengine/items/ES/items_views.py", line 38, in sell_items 
    res = s.execute() 
    File "/usr/local/lib/python2.7/dist-packages/elasticsearch_dsl/search.py", line 573, in execute 
    **self._params 
    File "/usr/local/lib/python2.7/dist-packages/elasticsearch/client/utils.py", line 69, in _wrapped 
    return func(*args, params=params, **kwargs) 
    File "/usr/local/lib/python2.7/dist-packages/elasticsearch/client/__init__.py", line 530, in search 
    doc_type, '_search'), params=params, body=body) 
    File "/usr/local/lib/python2.7/dist-packages/elasticsearch/transport.py", line 307, in perform_request 
    status, headers, data = connection.perform_request(method, url, params, body, ignore=ignore, timeout=timeout) 
    File "/usr/local/lib/python2.7/dist-packages/elasticsearch/connection/http_urllib3.py", line 93, in perform_request 
    self._raise_error(response.status, raw_data) 
    File "/usr/local/lib/python2.7/dist-packages/elasticsearch/connection/base.py", line 105, in _raise_error 
    raise HTTP_EXCEPTIONS.get(status_code, TransportError)(status_code, error_message, additional_info) 
RequestError: TransportError(400, u'search_phase_execution_exception') 

Répondre

2

Vous y êtes presque, vous n'avez pas besoin de réaffecter la référence à s le résultat de l'appel aggs.bucket (c.-à-pas besoin de la variable a), il suffit de faire comme ceci:

s = Items.search() #Items is DSL class 
s.aggs.bucket('SP', 'terms', field=item_name).metric('max_amt', 'max', field='amount') 
res = s.execute()   ^
           | 
      + change this to "field" instead of "item" 

# do something with the aggs 
for term in response.aggregations.SP.buckets: 
    print(term.key, term.max_amt.value) 
+0

Je reçois une erreur de transport lorsque vous le faites à votre façon. augmentation HTTP_EXCEPTIONS.get (status_code, TransportError) (status_code, error_message, additional_info) RequestError: TransportError (400, u'search_phase_execution_exception ') – Shipra

+0

Intéressant, pouvez-vous mettre à jour votre question avec l'erreur complète que vous obtenez? La requête est maintenant générée et envoyée, donc cela pourrait être un autre problème maintenant. – Val

+0

Vous avez une faute de frappe dans votre requête (c'est-à-dire 'field =' au lieu de 'item ='), veuillez vérifier ma réponse mise à jour. – Val