分类筛选过滤器

分类筛选过滤器

>: pip install django-filter

二、分类筛选过滤器

# 分类筛选:django-filter:filter_backends配置DjangoFilterBackend,再在filter_fields中配置分组筛选的字段
from django_filters.rest_framework import DjangoFilterBackend

class FreeCourseListAPIView(ListAPIView):
    queryset = models.Course.objects.filter(is_delete=False, is_show=True).order_by('orders').all()
    serializer_class = serializers.FreeCourseModelSerializer
  
    # 自定义过滤器
    filter_backends = [DjangoFilterBackend]  

   # 参与分类筛序的字段,所有字段都可以,但是分组字段要有意义
   # 分类字段是要序列化的字段获取序列化字段中的字段,就可以直接分类
   # http://127.0.0.1:8000/course/free?course_category=2
    filter_fields = ["course_category"] # 要筛选的字段(序列化字段)

三、 自定义区间删选过滤器

# 参考DjangoFilterBackend类中
if filterset_fields and queryset is not None:
    MetaBase = getattr(self.filterset_base, 'Meta', object)

    class AutoFilterSet(self.filterset_base):
        class Meta(MetaBase):
            model = queryset.model
            fields = filterset_fields

            return AutoFilterSet
# 1.自定义区间过滤器类
# 基于django-filter插件,完成指定区间筛选(一般都是对应数字字段)

from django_filters.rest_framework.filterset import FilterSet
from django_filters import filters
from . import models

class CourseFilterSet(FilterSet):
    max_price = filters.NumberFilter(field_name="price", lookup_expr="lte")
    min_price = filters.NumberFilter(field_name="price", lookup_expr="gte")

    class Meta:
        model = models.Course
        # 过滤的字段,序列化中的字段
        fields = ["course_category", "max_price", "min_price"]
        
# 2.使用
# 自定义的区间筛序选过滤器
from .filters import CourseFilterSet


class FreeCourseListAPIView(ListAPIView):
    queryset = models.Course.objects.filter(is_delete=False, is_show=True).order_by('orders').all()
    serializer_class = serializers.FreeCourseModelSerializer
    # 自定义类
    filter_class = CourseFilterSet
# eg: http://127.0.0.1:8000/course/free?min_price=2&max_price=100
# eg: http://127.0.0.1:8000/course/free?course_category=2

自定义filter类时的字段

models.AutoField:                   {'filter_class': NumberFilter},
models.CharField:                   {'filter_class': CharFilter},
models.TextField:                   {'filter_class': CharFilter},
models.BooleanField:                {'filter_class': BooleanFilter},
models.DateField:                   {'filter_class': DateFilter},
models.DateTimeField:               {'filter_class': DateTimeFilter},
models.TimeField:                   {'filter_class': TimeFilter},
models.DurationField:               {'filter_class': DurationFilter},
models.DecimalField:                {'filter_class': NumberFilter},
models.SmallIntegerField:           {'filter_class': NumberFilter},
models.IntegerField:                {'filter_class': NumberFilter},
models.PositiveIntegerField:        {'filter_class': NumberFilter},
models.PositiveSmallIntegerField:   {'filter_class': NumberFilter},
models.FloatField:                  {'filter_class': NumberFilter},
models.NullBooleanField:            {'filter_class': BooleanFilter},
models.SlugField:                   {'filter_class': CharFilter},
models.EmailField:                  {'filter_class': CharFilter},
models.FilePathField:               {'filter_class': CharFilter},
models.URLField:                    {'filter_class': CharFilter},
models.GenericIPAddressField:       {'filter_class': CharFilter},
models.CommaSeparatedIntegerField:  {'filter_class': CharFilter},
models.UUIDField:                   {'filter_class': UUIDFilter},
posted @ 2020-02-10 22:29  RandySun  阅读(715)  评论(0编辑  收藏  举报