1

views.py如何使用Django的休息与mongoengine用于过滤列表过滤

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 

这是我的代码。

它的工作原理是精确地筛选我们想要的东西。

例如:http://api/tool/?district=Nasik&crop=banana

但是,它不工作的列表的Fileds 例如:http://api/tool/?district=Nasik&district=Pune 这给了输出:[](空)

如何获得此过滤器的工作来获取所有区“纳西克”,区‘普纳’

能否请你帮我,我不得不为获取数据在我的代码的变化,如果我搜索http://api/tool/?crops=guava,banana 或http:../工具/区=纳西克,浦那
给我正确的输出?

回答

1

我推荐看看django-rest-framework-filters。然后,您可以使用这样的东西在你的查询参数__in ...

但是如果你想用你的方法来进行,我会在你的get_kwargs_for_filtering方法在某种程度上增加了逻辑是这样的:

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 

有了这个,拨打http://api/tool/?crops=guava,banana的电话应产生所需的行为。 我无法测试它现在是否有效,但是这应该引导您朝正确的方向发展。

+0

,你的意思是在我的领域= {'name':['exact','in','startswith']}我必须使用这个? –

+0

你可以请给我一些提示,它会帮助你 –

+0

真棒...非常感谢,这正是我想要的...... !!!搜索1000个问题后得到正确的答案。 –