46.drf过滤、搜索、排序
DRF的过滤类
- BaseFilterBackend:过滤基类,留好占位方法待后续继承
- SearchFilter:继承BaseFilterBackend
- OrderingFilter:继承BaseFilterBackend
- DjangoObjectPermissionsFilter:继承BaseFilterBackend,3.9版本之后废除
过滤的使用
示例1-根据模型字段进行过滤
# 继承的ModelViewSet
class GetInfoLIst(ModelViewSet):
queryset = UserInfo.objects.all()
serializer_class = UserSerializer
# 重写过滤方法
def get_queryset(self):
# 获取当前用户username
username = self.request.user.username
# 过滤出与当前用户username一致的信息
return UserInfo.objects.filter(username=username)
示例2-根据url路径进行过滤
#路由
path('user/<str:username>/', UserList.as_view()),
# views
# url示例: 127.0.0.1:8000/user/username/
class UserList(ListAPIView):
serializer_class = UserSerializer
def get_queryset(self):
# 获取请求路由中的username
username = self.kwargs['username']
return UserInfo.objects.filter(username=username)
示例3-根据url携带参数进行过滤
#url 示例:127.0.0.1:8000/user/?username=xxxx
# 继承的ModelViewSet
class GetInfoLIst(ModelViewSet):
queryset = UserInfo.objects.all()
serializer_class = UserSerializer
# 重写过滤方法
def get_queryset(self):
#从url参数中获取username,如果没有则是None
# query_params.get是从url获取参数的方法
username = self.request.query_params.get('username',None)
if username is None:
return UserInfo.object.all()
else:
return UserInfo.objects.filter(username=username)
DRF三种过滤的工具
DjangoFilterBackend
#安装
pip3.9 install django-filter
#注册
INSTALLED_APPS = [
'django_filters',
]
REST_FRAMEWORK = {
# 全局过滤配置
'DEFAULT_FILTER_BACKENDS':
# 值是元组,将django_filters配置上,进行全局性的过滤
('django_filters.rest_framework.DjangoFilterBackend',)
}
from django_filters.rest_framework import DjangoFilterBackend #导包
class UserList(ListAPIView):
# 视图级别过滤
filter_backends = (DjangoFilterBackend,)# 指定后端
from django_filters.rest_framework import DjangoFilterBackend #导包
class UserList(ListAPIView):
filter_backends = (DjangoFilterBackend,) # 指定后端
filterset_fields = ('username','id') #要过滤的字段
'''
将为指定的字段自动创建一个 FilterSet 类
可以发送类似请求: http://xxxx/api/xxx?username=xxxx&id=xxxx
Django-filter模块的默认模式是完全匹配模式,需要自定义匹配模式参考https://django-filter.readthedocs.io/en/latest/index.html
'''
SearchFilter搜索过滤
from rest_framework import filters
class UserList(ListAPIView):
filter_backends = (DjangoFilterBackend,filters.SearchFilter) # 指定后端
# 视图中设置了 search_fields 属性时,才会应用 SearchFilter 类
# search_fields只支持文本类型字段,例如 CharField 或 TextField
search_fields = ('username',)
'''
在url中默认的搜索参数是search
url示例 - http://xxxx/api/users?search=木子
会过滤出username=木子的信息
'''
# 上述默认以及search字段进行搜索,如果想要修改默认的search字段
REST_FRAMEWORK = {
# 全局过滤配置
'DEFAULT_FILTER_BACKENDS':
# 值是元组,将django_filters配置上,进行全局性的过滤
('django_filters.rest_framework.DjangoFilterBackend',)
# 修改search_fields链接搜索时的字段
"SEARCH_PARAM":"find"
}
"""
url示例 - http://xxxx/api/users?find=木子
"""
- ^ 以指定内容开始
- = 完全匹配
- @ 全文搜索(目前只支持Django的MySQL后端)
- $ 正则搜索
search_fields = ('=username') # 用户名必须完全一致,不能局部一致
OrderingFilter排序
class UserList(ListAPIView):
filter_backends = (filters.OrderingFilter) # 指定后端
ordering_filter = ('username',) # 指定可以排序的字段
ordering_fields = '__all__' # 所有字段,和指定二选一
'''
url中的查询参数默认ordering
http://xxxx/api/user?ordering=username
和search一样,如果要修改默认的查询参数,可以通过 ORDERING_PARAM指定
'''
#排序
http://xxxx/api/user?ordering=username # 默认排序
http://xxxx/api/user?ordering=-username #反向排序
http://xxxx/api/user?ordering=username,age #多个字段进行排序
指定默认的排序方式
class UserList(ListAPIView):
filter_backends = (filters.OrderingFilter) # 指定后端
ordering_filter = ('username',) # 指定可以排序的字段
ordering = ('username') #默认初始用username排序
46.drf过滤、搜索、排序的更多相关文章
- drf过滤和排序及异常处理的包装
过滤和排序(4星) 查询所有才需要过滤(根据过滤条件),排序(按某个规律排序) 使用前提: 必须继承的顶层类是GenericAPIView 内置过滤类 内置过滤类使用,在视图类中配置,是模糊查询 使用 ...
- DRF:过滤&搜索&排序功能
过滤功能利用的是第三方包 django_filters,搜索和排序利用的是 Django DRF 提供的 filters 示例代码如下: from rest_framework import filt ...
- Django(67)drf搜索过滤和排序过滤
前言 当我们需要对后台的数据进行过滤的时候,drf有两种,搜索过滤和排序过滤. 搜索过滤:比如我们想返回sex=1的,那么我们就可以从所有数据中进行筛选 排序过滤:比如我们想对价格进行升序排列,就可以 ...
- drf_jwt手动签发与校验-drf小组件:过滤-筛选-排序-分页
签发token 源码的入口:完成token签发的view类里面封装的方法. 源码中在请求token的时候只有post请求方法,主要分析一下源码中的post方法的实现. settings源码: 总结: ...
- [Android分享] 【转帖】Android ListView的A-Z字母排序和过滤搜索功能
感谢eoe社区的分享 最近看关于Android实现ListView的功能问题,一直都是小伙伴们关心探讨的Android开发问题之一,今天看到有关ListView实现A-Z字母排序和过滤搜索功能 ...
- Android 实现ListView的A-Z字母排序和过滤搜索功能,实现汉字转成拼音
转载:http://blog.csdn.net/xiaanming/article/details/12684155 转载请注明出处:http://blog.csdn.net/xiaanming/ar ...
- Elasticsearch高级搜索排序( 中文+拼音+首字母+简繁转换+特殊符号过滤)
一.先摆需求: 1.中文搜索.英文搜索.中英混搜 如:"南京东路","cafe 南京东路店" 2.全拼搜索.首字母搜索.中文+全拼.中文+首字母混搜 如 ...
- 学习ASP.NET Core(08)-过滤搜索与分页排序
上一篇我们介绍了AOP的基本概览,并使用动态代理的方式添加了服务日志:本章我们将介绍过滤与搜索.分页与排序并添加对应的功能 注:本章内容大多是基于solenovex的使用 ASP.NET Core 3 ...
- DRF 过滤排序分页异常处理
DRF 中如何使用过滤,排序,分页,以及报错了如何处理?10分钟get了~
随机推荐
- 【HTML】学习路径5-预格式标签和字体标签
<!DOCTYPE html> <html> <head> <title>我是标题</title> <meta charset=&qu ...
- Tomcat入门学习笔记
Tomcat服务器 Tomcat使用 Tomcat下载 官网地址:Apache Tomcat - Apache Tomcat 8 Software Downloads 下载Windows 64位版To ...
- MFRC522学习笔记
MFRC522主要特性 容量为8K位(bits)=1K字节(bytes)EEPROM 分为16个扇区,每个扇区为4块,每块16个字节,以块为存取单位 每个扇区有独立的一组密码及访问控制 每张卡有唯一序 ...
- Helm安装ingress-nginx-4.0.19
Application version 1.1.3 Chart version 4.0.19 获取chart包 helm fetch ingress-nginx/ingress-nginx --ver ...
- 解决前端开发报错(SyntaxError: missing : after property id)的问题
当使用对象初始化语法创建对象的时候,需要使用半角冒号 (:) 将属性键与属性值隔开. 1 var obj = { propertyKey: 'value' }; 冒号与等号 下面的代码会运行失败,原因 ...
- PostgreSQL 绑定变量窥探
今天我们要探讨的是 custom执行计划和通用执行计划.这一技术在 Oracle中被称为绑定变量窥视.但 Kingbase中并没有这样的定义,更严格地说,Kingbase叫做custom执行计划和通用 ...
- Nginx超时问题解决
在 nginx.conf 中配置以下内容 ... http { ... server { # 这里表示upstream 的连接.读取.发送超时时间都是300秒 proxy_connect_timeou ...
- spark 写入数据到Geomesa(Hbase)
package com.grady.geomesa import org.apache.spark.sql.jts.PointUDT import org.apache.spark.sql.types ...
- Windows 10 索引设置
有时候想找一下电脑上的某个文件,但是只记得关键字不记得文件名的信息了.这个时候就会尝试在Windows的窗口中搜索.不过有时候明明文件存在,但是无法找到文件.这个时候就需要检查索引设置了.https: ...
- MySQL8.0报错:Access denied; you need (at least one of) the SYSTEM_USER privilege(s) for this operation
MySQL8.0.16版本中新增了一个system_user帐户类型,当新增用户并赋予权限时 mysql> create user 'proxysql'@'192.168.20.%' ident ...