2013-04-15 18 views
8

Jak wykonać filtr w modelu Django za pomocą słownika zamiast argumentów metody? To co mam tu:Model filtru Django według słownika

class StoreView(TemplateView): 

    def get(self, request): 

     # A bunch of gets 
     sort = request.GET.get('sort') 
     sort_price = request.GET.get('sort_price') 
     sort_mfr_method = request.GET.get('mfr_method') 

     # The params tpsort by 
     sort_params = {} 

     if sort is not None: 
      sort_params['sort'] = sort 

     if sort_price is not None: 
      sort_params['sort_price'] = sort_price 

     if sort_mfr_method is not None: 
      sort_params['sort_mfr_method'] = sort_mfr_method 

     # The Model Query 
     design_list = models.Design.objects.filter(sort_params) 

     # etc... 

Side Pytanie, czy istnieje lepszy sposób ustawić wartości słownikowych niż to, co robię powyżej? Taki jak trójskładnik, ale w taki sposób, że wartość nie istnieje, jeśli nie ma?

sort_params['sort'] = sort if not None else '' 
+0

http://stackoverflow.com/questions/15949816/ use-string-variable-kwargs-as-named-argument –

Odpowiedz

15

użyć słownika przekazywać argumenty słów kluczowych tak:

models.Design.objects.filter(**sort_params) 

 

Nie ma wbudowany w sposób warunkowo ustawić klucz dict, ale jeśli zrobisz to na dużo, możesz napisać własną:

def set_if_not_none(mapping, key, value): 
    if value is not None: 
     mapping[key] = value 

class StoreView(TemplateView): 

    def get(self, request): 

     # A bunch of gets 
     sort = request.GET.get('sort') 
     sort_price = request.GET.get('sort_price') 
     sort_mfr_method = request.GET.get('mfr_method') 

     # The params tpsort by 
     sort_params = {} 

     set_if_not_none(sort_params, 'sort', sort) 
     set_if_not_none(sort_params, 'sort_price', sort_price) 
     set_if_not_none(sort_params, 'sort_mfr_method', sort_mfr_method) 

     # The Model Query 
     design_list = models.Design.objects.filter(**sort_params) 
+0

To działa doskonale! Ma to sens, ponieważ filtr ".filter" jest prawdopodobnie zdefiniowany w pobliżu: 'filter (* args, ** kwargs)' Po prostu nigdy nie zdawałem sobie sprawy, że możesz zrobić powyższe, co jest niesamowite! Dzięki – JREAM

4

abo Odpowiedź ve jest właściwa i proponuję bardziej wydajną.

tutaj request.GET jest QueryDict Wystarczy przekształcić go w Słowniku jak ten

kwargs = dict(request.GET)

i teraz filtrować to

models.Design.objects.filter(**kwargs)

Powiązane problemy