1

views.pywie django Rest für Listenfilterung mit mongoengine Filterung verwenden

from __future__ import unicode_literals 

from rest_framework_mongoengine.viewsets import ModelViewSet as MongoModelViewSet 

from app.serializers import * 

from rest_framework_mongoengine.generics import * 

from rest_framework import filters  


def index_view(request): 
    context = {} 
    return TemplateResponse(request, 'index.html', context) 


class ToolViewSet(MongoModelViewSet): 
    serializer_class = ToolSerializer 
    my_filter_fields = ('crop', 'district','taluka','circle','year',) 

    def get_kwargs_for_filtering(self): 
     filtering_kwargs = {} 

     for field in self.my_filter_fields: # iterate over the filter fields 
      field_value = self.request.query_params.get(field) # get the value of a field from request query parameter 
      if field_value: 
       filtering_kwargs[field] = field_value 
     return filtering_kwargs 

    def get_queryset(self): 
     queryset = Tool.objects.all() 
     filtering_kwargs = self.get_kwargs_for_filtering() # get the fields with values for filtering 
     if filtering_kwargs: 
      queryset = Tool.objects.filter(**filtering_kwargs) # filter the queryset based on 'filtering_kwargs' 
     return queryset 

Dies ist mein Code.

es ist Arbeit zum Filtern genau, was wir suchen möchten.

zum Beispiel: http://api/tool/?district=Nasik&crop=banana

Aber es ist nicht für die Liste arbeitet fileds zum Beispiel: http://api/tool/?district=Nasik&district=Pune das gibt Ausgang: [] (Leer)

Wie diese Filter zum Laufen bringen alle Bezirke zu bekommen " Nasik“OR Bezirk "Pune"

können Sie mir bitte helfen, was ich Änderungen in meinem Code für get Daten haben, wenn ich http://api/tool/?crops=guava,banana Oder http suchen: ../ Werkzeug/Bezirk = Nasik, Pune
gibt mir korrekte Ausgabe?

Antwort

1

Ich empfehle, einen Blick auf django-rest-framework-filters. Sie können dann Sachen wie __in in Ihrer Abfrage params verwenden ...

Aber wenn Sie mit Ihrem Ansatz fortfahren möchten, würde ich die Logik in Ihrer get_kwargs_for_filtering Methode irgendwie wie folgt hinzu:

def get_kwargs_for_filtering(self): 
    filtering_kwargs = {} 

    for field in self.my_filter_fields: # iterate over the filter fields 
     field_value = self.request.query_params.get(field) # get the value of a field from request query parameter 
     if field_value: 
      if ',' in field_value: # put your queryParams into an array and use the built-in django filter method '__in' 
       filtering_kwargs[field + '__in'] = field_value.split(',') 
      else: 
       filtering_kwargs[field] = field_value 
    return filtering_kwargs 

Mit diesem sollte ein Aufruf an http://api/tool/?crops=guava,banana das gewünschte Verhalten erzeugen. Ich kann nicht testen, ob es jetzt funktioniert, aber das sollte dich in die richtige Richtung führen.

+0

, meinst du In meinen Feldern = {'name': ['genau', 'in', 'startswith']} muss ich das verwenden? –

+0

Kannst du mir bitte einen Hinweis geben, es hilft –

+0

du bist super ... vielen Dank, das ist genau was ich will ... !!! Nach der Suche 1000 Frage erhalten Sie die richtige Antwort. –

Verwandte Themen