DRF的过滤与排序

  • 过滤

对于列表数据可能需要根据字段进行过滤,我们可以通过添加 django-filter 扩展来增强支持。

pip install django-filter

在配置文件中增加过滤后端的设置:

INSTALLED_APPS = [
    ...
    'django_filters',  # 需要注册应用,
]

 

  • 全局配置

在settings文件中配置:

REST_FRAMEWORK = {
    'DEFAULT_FILTER_BACKENDS': ('django_filters.rest_framework.DjangoFilterBackend',)  # 全局配置,对全部视图的查询多条接口都有过滤功能,但是视图里要指定字段
}

视图中指定要过滤的字段:

class EmployeeViewSet(ModelViewSet):
    queryset = Employee.objects.all()
    serializer_class = EmployeeSerializer
    # 指定可以根据哪些字段进行列表数据的过滤
    filter_fields = ('gender', 'department')

 

  • 针对某个视图进行过滤(比较常用)

class EmployeeViewSet(ModelViewSet):
    queryset = Employee.objects.all()
    serializer_class = EmployeeSerializer

    # 指定过滤器
    filter_backends = [DjangoFilterBackend]
    # 指定可以根据哪些字段进行列表数据的过滤
    filterset_fields = ('gender', 'department')

 

  • 使用

访问127.0.0.1/employees?gender=1时可以过滤出性别字段是1的数据。

===================================================================================================================================

  • 排序

对于列表数据,REST framework 提供了 OrderingFilter 过滤器 来实现按指定字段进行排序的功能

使用方法:

  • 在类视图中设置filter_backends,使用 rest_framework.filters.OrderingFilter(自带的模块,导包时注意) 过滤器:REST framework会在请求的查询字符串参数中检查是否包含了 ordering 参数,如果包含,则按照 ordering 参数指定的字段对数据集进行排序。
  • 在类视图中指定 ordering_fields属性,表示前端请求列表数据时,可以通过哪些字段进行排序

 

设置示例:

class EmployeeViewSet(ModelViewSet):

    queryset = Employee.objects.all()
    serializer_class = EmployeeSerializer

    # 新增排序的过滤器
    filter_backends = [..., OrderingFilter]
    # 指定可以根据哪此字段进行排序
    ordering_fields = ('age', 'salary')

 

使用示例:

访问127.0.0.1/employees/?ordering=age(年龄升序)

访问127.0.0.1/employees/?ordering=-age(年龄降序)

访问127.0.0.1/employees/?ordering=age,-salary(先安装年龄升序来排,如果年龄一样,按工资升序来排)

转载于:https://www.cnblogs.com/chichung/p/9945295.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值