• 企业400电话
  • 网络优化推广
  • AI电话机器人
  • 呼叫中心
  • 全 部 栏 目

    网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    Django实现drf搜索过滤和排序过滤
    POST TIME:2021-10-18 13:25

    前言

    当我们需要对后台的数据进行过滤的时候,drf有两种,搜索过滤和排序过滤。
    搜索过滤:比如我们想返回sex=1的,那么我们就可以从所有数据中进行筛选
    排序过滤:比如我们想对价格进行升序排列,就可以使用排序过滤

    搜索过滤

    在实际的使用过程中十分简单,只需要在视图类中配置一个全局变量filter_backends,然后在search_fields确定需要通过哪个字段进行筛选

    from rest_framework.filters import SearchFilter
    class CarView(ListAPIView):
        serializer_class = CarSerializer
        queryset = Car.objects.all()
        # 局部配置过滤类和排序类
        filter_backends = [SearchFilter]
        # SearchFilter过滤类依赖的过滤条件
        search_fields = ['name']

    之后我们在访问url地址时,就可以在url后面添加?search="宝马1系",那么我们就会过滤出name="宝马1系"的数据


    排序过滤

    跟搜索过滤一样,只需要配置局部变量filter_backends,然后配置ordering_fields来确定通过哪个字段进行排序

    from rest_framework.filters import SearchFilter, OrderingFilter
    class CarView(ListAPIView):
        serializer_class = CarSerializer
        queryset = Car.objects.all()
        # 局部配置过滤类和排序类
        filter_backends = [SearchFilter, OrderingFilter]
        # SearchFilter过滤类依赖的过滤条件
        search_fields = ['name']
        # 局部配置排序类
        ordering_fields = ['price']

    之后我们在访问url地址时,就可以在url后面添加?search="宝马"ordering="price",那么我们就会过滤出所有宝马系列的车子,并且数据的排序按照车的价格从低到高排序

    PS:过滤功能利用的是第三方包 django_filters,搜索和排序利用的是 Django DRF 提供的 filters

    from rest_framework import filters # 搜索和排序功能 # 注意:这两个是 DRF 提供的功能
    
    from django_filters.rest_framework import DjangoFilterBackend  # DjangoFilterBackend 是精确(查找)过滤,即 字段值必须要完全一样才能匹配成功
    import django_filters
    
    class GoodsFilter(django_filters.rest_framework.FilterSet):
        """商品的过滤类"""
        min_price = django_filters.NumberFilter(field_name="price",
                                                lookup_expr="gte")  # field_name 表示要过滤字段;lookup_expr 表示 过滤时要进行的操作,gte 表示 大于等于
        max_price = django_filters.NumberFilter(field_name="price", lookup_expr="lte")  # lte 小于等于
        name = django_filters.CharFilter(field_name="name",lookup_expr="icontains")  # icontains 表示 包含(忽略大小写)
    
        class Meta:
            model = models.Goods  # 关联的表
            fields = ["min_price","max_price","name"]  # 过滤的字段
    
    
    class GoodsPagination(PageNumberPagination):
        page_size = 10
        page_size_query_param = "page_size"
        page_query_param = "p"
        max_page_size = 100
    
    class GoodsListViewSet(mixins.ListModelMixin,GenericViewSet):
        """商品查看"""
        queryset = models.Goods.objects.all() # 没 get_queryset() 这个过滤方法时,需要写上这一步的 queryset;有 get_queryset 方法时,则不需要写这一步,因为会自动去 get_queryset() 中找 queryset
        pagination_class = GoodsPagination
        
        # 方式三:自定义过滤功能(也包含搜索和排序功能)
        filter_backends = (DjangoFilterBackend,filters.SearchFilter,filters.OrderingFilter)  # filters.SearchFilter 表示 搜索功能;filters.OrderingFilter 表示 排序功能
        filterset_class = GoodsFilter  # 把自定义的过滤类 GoodsFilter 赋值给 filterset_class
        search_fields = ('^name', 'goods_brief')  # 搜索功能对应的字段 # '^' Starts-with search;'=' Exact matches.
        ordering_fields = ("sold_num","add_time") # 排序功能对应的字段 
        
        # 业务逻辑省略...
        
        """
        # 过滤功能方式二
        filter_backends = (DjangoFilterBackend,) # 过滤类型
        filterset_fields = ("name","shop_price")  # 过滤字段  # 这种的过滤只能满足精确过滤
        """
        
        """
        # 方式一:get_queryset()方法
        def get_queryset(self):  # 过滤方法; GenericAPIView 提供的方法
            queryset = models.Goods.objects.all()
            price_min = self.request.query_params.get("price_min",0)
            if price_min:
                queryset = queryset.filter(shop_price_gt=int(price_min))
            return queryset
        """
        
        """
        方式二:通过 django-filter
        # 1. pip install django-filter
        # 2. 把 "django-filters" 添加到 Django 的 INSTALLED_APPS 中
        # 3. 在 filter_backends 中添加 DjangoFilterBackend,在 filterset_fields 中添加 过滤字段
        这个方式的过滤是精确过滤,即 用户传过来的值必须和 对应过滤字段的值完全一样才能过滤出来;
        如果想自定义过滤功能(例如想过滤出价格区间),可通过方式三
        """
        
        """
        方式三:通过 django-filter 自定义 过滤功能
        1. 自定义一个过滤类
        2. filter_backends = (DjangoFilterBackend,)
        3. filterset_class = GoodsFilter  # 把自定义的过滤类 GoodsFilter 赋值给 filterset_class
        """

    到此这篇关于Django实现drf搜索过滤和排序过滤的文章就介绍到这了,更多相关drf搜索过滤和排序过滤内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

    您可能感兴趣的文章:
    • DRF过滤排序分页异常处理的过程记录
    上一篇:python生成可执行exe控制Microsip自动填写号码并拨打功能
    下一篇:利用Python第三方库实现预测NBA比赛结果
  • 相关文章
  • 

    关于我们 | 付款方式 | 荣誉资质 | 业务提交 | 代理合作


    © 2016-2020 巨人网络通讯

    时间:9:00-21:00 (节假日不休)

    地址:江苏信息产业基地11号楼四层

    《增值电信业务经营许可证》 苏B2-20120278

    X

    截屏,微信识别二维码

    微信号:veteran88

    (点击微信号复制,添加好友)

     打开微信