Django实现drf搜索过滤和排序过滤


Posted in Python onJune 21, 2021

前言

当我们需要对后台的数据进行过滤的时候,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系"的数据

Django实现drf搜索过滤和排序过滤

排序过滤

跟搜索过滤一样,只需要配置局部变量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",那么我们就会过滤出所有宝马系列的车子,并且数据的排序按照车的价格从低到高排序

Django实现drf搜索过滤和排序过滤

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搜索过滤和排序过滤内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python实现公历(阳历)转农历(阴历)的方法示例
Aug 22 Python
Python排序搜索基本算法之插入排序实例分析
Dec 11 Python
python调用c++ ctype list传数组或者返回数组的方法
Feb 13 Python
python selenium爬取斗鱼所有直播房间信息过程详解
Aug 09 Python
python 实现多线程下载m3u8格式视频并使用fmmpeg合并
Nov 15 Python
python 实现兔子生兔子示例
Nov 21 Python
Python类继承和多态原理解析
Feb 05 Python
利用Python自动化操作AutoCAD的实现
Apr 01 Python
关于matplotlib-legend 位置属性 loc 使用说明
May 16 Python
Python爬虫定时计划任务的几种常见方法(推荐)
Jan 15 Python
详解非极大值抑制算法之Python实现
Jun 28 Python
Python first-order-model实现让照片动起来
Jun 25 Python
python生成可执行exe控制Microsip自动填写号码并拨打功能
详解Python自动化之文件自动化处理
Jun 21 #Python
Python Pandas pandas.read_sql_query函数实例用法分析
Jun 21 #Python
Python Pandas pandas.read_sql函数实例用法
Jun 21 #Python
浅谈Python从全局与局部变量到装饰器的相关知识
Jun 21 #Python
Python-OpenCV教程之图像的位运算详解
Python中的套接字编程是什么?
You might like
一个ORACLE分页程序,挺实用的.
2006/10/09 PHP
header()函数使用说明
2006/11/23 PHP
ThinkPHP使用心得分享-ThinkPHP + Ajax 实现2级联动下拉菜单
2014/05/15 PHP
php输出xml必须header的解决方法
2014/10/17 PHP
PHP中的switch语句的用法实例详解
2015/10/21 PHP
PHP 输出缓冲控制(Output Control)详解
2016/08/25 PHP
Laravel 批量更新多条数据的示例
2017/11/27 PHP
javascript网页关键字高亮代码
2008/07/30 Javascript
jquery 操作两个select实现值之间的互相传递
2014/03/07 Javascript
NodeJS学习笔记之Connect中间件模块(二)
2015/01/27 NodeJs
实例代码详解javascript实现窗口抖动及qq窗口抖动
2016/01/04 Javascript
javascript创建对象、对象继承的实用方式详解
2016/03/08 Javascript
原生js实现自由拖拽弹窗代码demo
2016/06/29 Javascript
探讨跨域请求资源的几种方式(总结)
2016/12/02 Javascript
Bootstrap栅格系统的使用和理解2
2016/12/14 Javascript
详解从angular-cli:1.0.0-beta.28.3升级到@angular/cli:1.0.0
2017/05/22 Javascript
vue实现全选、反选功能
2020/11/17 Javascript
vue增删改查的简单操作
2017/07/15 Javascript
vue引入ueditor及node后台配置详解
2018/01/03 Javascript
浅谈Vue.js 中的 v-on 事件指令的使用
2018/11/25 Javascript
node基于async/await对mysql进行封装
2019/06/20 Javascript
小程序websocket心跳库(websocket-heartbeat-miniprogram)
2020/02/23 Javascript
Python制作豆瓣图片的爬虫
2017/12/28 Python
Python 实现字符串中指定位置插入一个字符
2018/05/02 Python
Pycharm取消py脚本中SQL识别的方法
2018/11/29 Python
详解基于python-django框架的支付宝支付案例
2019/09/23 Python
解决Django中checkbox复选框的传值问题
2020/03/31 Python
Python web如何在IIS发布应用过程解析
2020/05/27 Python
阿联酋手表和配饰购物网站:Rivolishop
2019/11/25 全球购物
医学专业大学生求职的自我评价
2013/11/27 职场文书
中学生励志演讲稿
2014/04/26 职场文书
企业贷款委托书格式
2014/09/12 职场文书
入党现实表现材料
2014/12/23 职场文书
学习经验交流会策划书
2015/11/02 职场文书
初中美术教学反思
2016/02/17 职场文书
详解Oracle数据库中自带的所有表结构(sql代码)
2021/11/20 Oracle