1、定义一个自定义的filter.py模块,增加一个新的过滤类
import django_filters #这个Q可以支持表查询,单下划线获取表字段,双下划线获取关联表, from django.db.models import Q #引入自己的模型 from app.item.models import ItemCategory #自定义的过滤类,需要继承django_filter.rest_framework中的FilterSet类 class ItemCategoryFilter(django_filters.rest_framework.FilterSet): Filter_category = django_filters.NumberFilter(method='category_filter', label='Filter_category') #django_filters.NumberFilter类似,ModelForm中字段类型的控制 #其中method指向自己定义的过滤函数,label用于标识在测试API界面中的过滤界面字段,Filter_category控制查询字段 def category_filter(self, queryset, name, value): #这里用到多级联表查询 return queryset.filter(Q(category_id=value)|Q(category__parent_id=value)|Q(category__parent__parent_id=value)|Q(category__parent__parent__parent_id=value)) class Meta: model = ItemCategory fields = []
2、将视图处理类中的,过滤器后端重新指定,将过滤器类连接到我们自定义实现的处理类上
class ItemsListByCategory(generics.ListCreateAPIView): ''' 根据category编号获取相关模型no。 请求中请带有参数category @:require param: category such as: GET /itemsListByCategory/?Filter_category=2 ''' from django_filters.rest_framework import DjangoFilterBackend from app.item.filters import ItemCategoryFilter queryset = ItemCategory.objects.all() serializer_class = ItemCategorySerializer pagination_class = CommonPagination # 在这里哦 filter_backends = (DjangoFilterBackend,) filter_class =ItemCategoryFilter permission_classes = (ReadOnly,)
补充知识:Django restful framework 中的 filter 自定义过滤
class AlertFilter(django_filters.rest_framework.FilterSet): ....... to_bearer_service = django_filters.rest_framework.CharFilter(method='to_bearer_service_filter', label='bearer_service') class Meta: model = Alert fields = [......, 'to_bearer_service'] @staticmethod # 如果想获取请求信息可以去掉这个静态方法的装饰器,为什么要加静态方法装饰器我也不清楚 def to_bearer_service_filter(queryset, name, value): Q_id = Q() for i in value.split(","): if i == "0": Q_id.add(Q(**{'to_bearer_service':None}), Q.OR) else: Q_id.add(Q(**{'to_bearer_service_id': int(i)}), Q.OR) queryset = queryset.filter(Q_id) return queryset def to_bearer_service_filter(self, queryset, name, value): Q_id = Q() for i in value.split(","): if i == "0": Q_id.add(Q(**{'to_bearer_service':None}), Q.OR) else: Q_id.add(Q(**{'to_bearer_service_id': int(i)}), Q.OR) queryset = queryset.filter(Q_id) return queryset
以上这篇Django-rest-framework中过滤器的定制实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持小牛知识库。
问题内容: 在Django Rest Framework中,当一个序列化器嵌套在另一个序列化器中时,如何过滤它? 我的过滤器被强加在DRF视图集中,但是当您从另一个序列化器内部调用序列化器时,嵌套序列化器的视图集将永远不会被调用,因此嵌套结果看起来是未经过滤的。 我尝试在原始视图集上添加过滤器,但是它似乎无法过滤嵌套结果,因为嵌套结果被称为单独的预提取查询。(您看到嵌套的序列化程序是反向查找。)
本文向大家介绍django 自定义过滤器的实现,包括了django 自定义过滤器的实现的使用技巧和注意事项,需要的朋友参考一下 自定义模版过滤器 虽然DTL给我们内置了许多好用的过滤器。但是有些时候还是不能满足我们的需求。因此Django给我们提供了一个接口,可以让我们自定义过滤器,实现自己的需求。 模版过滤器必须要放在app中,并且这个app必须要在INSTALLED_APPS中进行安装。然后再
Django REST Framework 这个名字很直白,就是基于 Django 的 REST 框架。
本文向大家介绍Django 自定义过滤器,包括了Django 自定义过滤器的使用技巧和注意事项,需要的朋友参考一下 示例 过滤器允许您将函数应用于变量。此函数可以使用0或1参数。语法如下: 过滤器可以链接在一起,因此非常有效: 如果将其翻译成python,上面的代码行将给出以下内容: 在此示例中,我们将编写一个verbose_name适用于模型(实例或类)或QuerySet的自定义过滤器。它将返回
我用ImageField创建了一个简单的模型,我想用django-rest-framework+django-rest-swagger创建一个api视图,它是文档化的,并且能够上传文件。 以下是我得到的: 我阅读了django-rest-framework中的这部分文档: 我正在使用、和。