使用Django后端滤波器滤镜范围



我正在使用django rest框架在项目上工作,其中我必须过滤用户给出的不同参数。我正在使用django filter后端。 这是我的代码:

class FilterViewSet(viewsets.ModelViewSet):
serializer_class = SearchSerializer
#Filters on specific fields
filter_backends = (DjangoFilterBackend,)
filter_fields = ('property_zipcode','property_state', 
                 'property_county',
                 'property_city','property_area',)#range between 100 to 500 or area less then 500.
#range is pass by user as a property_area=300.
def filter_queryset(self, queryset):
    if self.request.query_params.get('property_state', None):
        queryset = super(FilterViewSet, self).filter_queryset(self.get_queryset())
        return queryset
    else:
        queryset = self.get_queryset()
        return queryset

一切正常。但是现在,我必须根据100平方英尺为500平方英尺的范围过滤property_area。如何使用Djangofter后端来实现这一目标?

谢谢@gabriel muj。从django滤波器文档中,我解决了我的问题。我创建了自己的过滤类添加的字段,该字段用于过滤器。

class Filter(django_filters.FilterSet):
    class Meta:
        model = Property
        fields = {
            'property_state': ['exact'],
            'year_built': ['lt', 'gt'],
            'tax':['lt','gt'],
        }

在Viewset中称其为:

    class FilterViewSet(viewsets.ModelViewSet):
          serializer_class = SearchSerializer
         #Filters on specific fields
          filter_class = Filter

        def filter_queryset(self, queryset):
             if self.request.query_params.get('property_state', None):
              queryset = super(FilterViewSet, self).filter_queryset(self.get_queryset())
              return queryset
          else:
              queryset = self.get_queryset()
              return queryset

相关内容

  • 没有找到相关文章

最新更新