drf 分页 排序,过滤

drf 分页 排序,过滤

1、频率功能源码刨析

# SimpleRateThrottle
	-源码里执行的频率类的allow_request,读SimpleRateThrottle的allow_request
    
class SimpleRateThrottle(BaseThrottle):
    cache = default_cache
    timer = time.time
    cache_format = 'throttle_%(scope)s_%(ident)s'
    scope = None
    THROTTLE_RATES = api_settings.DEFAULT_THROTTLE_RATES
    def __init__(self):  # 只要类实例化得到对象就会执行,一执行,self.rate就有值了,而且self.num_requests和self.duration
        if not getattr(self, 'rate', None): # 去频率类中反射rate属性或方法,发现没有,返回了None,这个if判断就符合,执行下面的代码
            self.rate = self.get_rate()  #返回了  '3/m'
        #  self.num_requests=3
        #  self.duration=60
        self.num_requests, self.duration = self.parse_rate(self.rate)

    def get_rate(self):
         return self.THROTTLE_RATES[self.scope] # 字典取值,配置文件中咱们配置的字典{'ss': '3/m',},根据ss取到了 '3/m'

    def parse_rate(self, rate):
        if rate is None:
            return (None, None)
        # rate:字符串'3/m'  根据 / 切分,切成了 ['3','m']
        # num=3,period=m
        num, period = rate.split('/')
        # num_requests=3  数字3
        num_requests = int(num)
        # period='m'  ---->period[0]--->'m'
        # {'s': 1, 'm': 60, 'h': 3600, 'd': 86400}[period[0]]
        # duration=60
        duration = {'s': 1, 'm': 60, 'h': 3600, 'd': 86400}[period[0]]
        # 3     60
        return (num_requests, duration)

    def allow_request(self, request, view):
        if self.rate is None:
            return True
        # 咱们自己写的,返回什么就以什么做限制  咱们返回的是ip地址
        # self.key=当前访问者的ip地址
        self.key = self.get_cache_key(request, view)
        if self.key is None:
            return True
        # self.history 访问者的时间列表,从缓存中拿到,如果拿不到就是空列表,如果之前有 [时间2,时间1]
        self.history = self.cache.get(self.key, [])
        # 当前时间
        self.now = self.timer()
        while self.history and self.history[-1] <= self.now - self.duration:
            self.history.pop()
        if len(self.history) >= self.num_requests:
            return self.throttle_failure()
        return self.throttle_success()
    
    
  # 总结:以后要再写频率类,只需要继承SimpleRateThrottle,重写get_cache_key,配置类属性scope,配置文件中配置一下就可以了

2、分页功能

查看所有接口 才需要分页
分页后端写法是固定前端展现形式是不一样的
pc端的下一页的点击
app中,翻页是下拉加载更多

drf中分页的使用:

  1. 写一个类,继承drf提供的三个分页类之一

  2. 重写某几个类属性

  3. 把它配置在继承自GenericAPIView+ListModelMixin的子视图类上

  4. 如果继承的是APIView,需要自己写

    page = MyPageNumberPagination()
    res = page.paginate_queryset(qs, request)
    return pag.get_paginated_response(ser.data)
    

2.1、分页类 实例

from rest_framework.pagination import PageNumberPagination, LimitOffsetPagination, CursorPagination


class MyPagination(PageNumberPagination):
    page_size = 2
    page_query_param = 'page'  # /books/?page=3  查询第几页参数
    page_size_query_param = 'size'  # /books/?page=3&size=4  # 查询第三页 每页显示四条参数
    max_page_size = 5  # 通过 size 拆线呢,最大显示 5条


class MyLimitOffsetPag(LimitOffsetPagination):
    default_limit = 2  # 每页显示的条数
    limit_query_param = 'limit'  # /books/?limit=4 这一页显示4条数据
    offset_query_param = 'offset'  # /books/?offset=3&limit=4  # 从第三条开始取四条数据
    max_limit = 5  # 最多 显示几条


class MyCursorPag(CursorPagination):
    cursor_query_param = 'cursor'
    page_size = 2  # 每页显示的条数
    ordering = 'id'  #排序 按表中的字段

3、排序功能

查询所有才涉及到排序,其它接口都不需要
必须是继承GenericAPIView+ListModelMixin的子视图类上

# 配置排序类:
filter_backends=[OrderingFilter,]
#配置排序的字段
ordering_fields=['id','price']

支持前端的访问形式

http://127.0.0.1:8000/books/?ordering=-price,id # 先按价格的降序排,如果价格一样再按id的升

纯自己写的,继承了APIView的,需要自己从请求地址中取出排序规则,自己排序

'price','-id'=reqeust.query_params.get('ordering').split(',')
qs = Book.objects.all().order_by('price','-id')

分页和排序能一起用,但是是先排序后分页的

4、过滤

查询所有才涉及到过滤,其它接口都不需要
restful规范中有一条,请求地址中带过滤条件:分页,排序,过滤统称为过滤

使用内置过滤类使用步骤 查询所有才涉及到排序,其它接口都不需要
必须是继承GenericAPIView+ListModelMixin的子视图类上

配置过滤类:
filter_backends=[SearchFilter,]
配置过滤的字段
search_fields=['name','publish']

支持前端的访问形式

http://127.0.0.1:8000/books/?search=# 只要name中或publish中有三都能搜出来
# 内置过滤类只能通过search写条件,如果配置了多个过滤字段,是或者的条件

不够用:
第三方:过滤类
自己写:自己写过滤类

扩展

继承APIView 实现分页

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-bhsfS8i2-1665414860434)(C:\Users\82576\AppData\Roaming\Typora\typora-user-images\image-20221010230023148.png)]

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值