溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè)

發(fā)布時(shí)間:2021-04-07 17:50:31 來(lái)源:億速云 閱讀:272 作者:Leah 欄目:開發(fā)技術(shù)

今天就跟大家聊聊有關(guān)如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè),可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

第一種分頁(yè)P(yáng)ageNumberPagination

(1)urls.py

urlpatterns = [
  re_path('(?P<version>[v1|v2]+)/page1/', Pager1View.as_view(),)  #分頁(yè)1
]

(2)api/utils/serializers/pager.py

# api/utils/serializsers/pager.py
from rest_framework import serializers
from api import models

class PagerSerialiser(serializers.ModelSerializer):
  class Meta:
    model = models.Role
    fields = "__all__"

(3)views.py

from api.utils.serializsers.pager import PagerSerialiser
from rest_framework.response import Response
from rest_framework.pagination import PageNumberPagination

class Pager1View(APIView):
  def get(self,request,*args,**kwargs):
    #獲取所有數(shù)據(jù)
    roles = models.Role.objects.all()
    #創(chuàng)建分頁(yè)對(duì)象
    pg = PageNumberPagination()
    #獲取分頁(yè)的數(shù)據(jù)
    page_roles = pg.paginate_queryset(queryset=roles,request=request,view=self)
    #對(duì)數(shù)據(jù)進(jìn)行序列化
    ser = PagerSerialiser(instance=page_roles,many=True)
    return Response(ser.data)

(4)settings配置

REST_FRAMEWORK = {
  #分頁(yè)
  "PAGE_SIZE":2  #每頁(yè)顯示多少個(gè)
}

如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè)

自定義分頁(yè)類

#自定義分頁(yè)類
class MyPageNumberPagination(PageNumberPagination):
  #每頁(yè)顯示多少個(gè)
  page_size = 3
  #默認(rèn)每頁(yè)顯示3個(gè),可以通過(guò)傳入pager1/?page=2&size=4,改變默認(rèn)每頁(yè)顯示的個(gè)數(shù)
  page_size_query_param = "size"
  #最大頁(yè)數(shù)不超過(guò)10
  max_page_size = 10
  #獲取頁(yè)碼數(shù)的
  page_query_param = "page"


class Pager1View(APIView):
  def get(self,request,*args,**kwargs):
    #獲取所有數(shù)據(jù)
    roles = models.Role.objects.all()
    #創(chuàng)建分頁(yè)對(duì)象,這里是自定義的MyPageNumberPagination
    pg = MyPageNumberPagination()
    #獲取分頁(yè)的數(shù)據(jù)
    page_roles = pg.paginate_queryset(queryset=roles,request=request,view=self)
    #對(duì)數(shù)據(jù)進(jìn)行序列化
    ser = PagerSerialiser(instance=page_roles,many=True)
    return Response(ser.data)

如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè)

第二種分頁(yè) LimitOffsetPagination

自定義

#自定義分頁(yè)類2
class MyLimitOffsetPagination(LimitOffsetPagination):
  #默認(rèn)顯示的個(gè)數(shù)
  default_limit = 2
  #當(dāng)前的位置
  offset_query_param = "offset"
  #通過(guò)limit改變默認(rèn)顯示的個(gè)數(shù)
  limit_query_param = "limit"
  #一頁(yè)最多顯示的個(gè)數(shù)
  max_limit = 10


class Pager1View(APIView):
  def get(self,request,*args,**kwargs):
    #獲取所有數(shù)據(jù)
    roles = models.Role.objects.all()
    #創(chuàng)建分頁(yè)對(duì)象
    pg = MyLimitOffsetPagination()
    #獲取分頁(yè)的數(shù)據(jù)
    page_roles = pg.paginate_queryset(queryset=roles,request=request,view=self)
    #對(duì)數(shù)據(jù)進(jìn)行序列化
    ser = PagerSerialiser(instance=page_roles,many=True)
    return Response(ser.data)

如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè)

如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè)

返回的時(shí)候可以用get_paginated_response方法

自帶上一頁(yè)下一頁(yè)

如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè)

如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè)

第三種分頁(yè)CursorPagination

加密分頁(yè)方式,只能通過(guò)點(diǎn)“上一頁(yè)”和下一頁(yè)訪問(wèn)數(shù)據(jù)

#自定義分頁(yè)類3 (加密分頁(yè))
class MyCursorPagination(CursorPagination):
  cursor_query_param = "cursor"
  page_size = 2   #每頁(yè)顯示2個(gè)數(shù)據(jù)
  ordering = 'id'  #排序
  page_size_query_param = None
  max_page_size = None

class Pager1View(APIView):
  def get(self,request,*args,**kwargs):
    #獲取所有數(shù)據(jù)
    roles = models.Role.objects.all()
    #創(chuàng)建分頁(yè)對(duì)象
    pg = MyCursorPagination()
    #獲取分頁(yè)的數(shù)據(jù)
    page_roles = pg.paginate_queryset(queryset=roles,request=request,view=self)
    #對(duì)數(shù)據(jù)進(jìn)行序列化
    ser = PagerSerialiser(instance=page_roles,many=True)
    # return Response(ser.data)
    return pg.get_paginated_response(ser.data)

如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè)

如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè)

代碼

版本、解析器、序列化和分頁(yè)

# MyProject2/urls.py

from django.contrib import admin
from django.urls import path,include

urlpatterns = [
  #path('admin/', admin.site.urls),
  path('api/',include('api.urls') ),
]
# api/urls.py

from django.urls import path,re_path
from .views import UserView,PaserView,RolesView,UserInfoView,GroupView,UserGroupView
from .views import Pager1View

urlpatterns = [
  re_path('(?P<version>[v1|v2]+)/users/', UserView.as_view(),name = 'api_user'), #版本
  path('paser/', PaserView.as_view(),),  #解析
  re_path('(?P<version>[v1|v2]+)/roles/', RolesView.as_view()),   #序列化
  re_path('(?P<version>[v1|v2]+)/info/', UserInfoView.as_view()),  #序列化
  re_path('(?P<version>[v1|v2]+)/group/(?P<pk>\d+)/', GroupView.as_view(),name = 'gp'),  #序列化生成url
  re_path('(?P<version>[v1|v2]+)/usergroup/', UserGroupView.as_view(),),  #序列化做驗(yàn)證
  re_path('(?P<version>[v1|v2]+)/pager1/', Pager1View.as_view(),)  #分頁(yè)1
]
# api/models.py

from django.db import models

class UserInfo(models.Model):
  USER_TYPE = (
    (1,'普通用戶'),
    (2,'VIP'),
    (3,'SVIP')
  )

  user_type = models.IntegerField(choices=USER_TYPE)
  username = models.CharField(max_length=32,unique=True)
  password = models.CharField(max_length=64)
  group = models.ForeignKey('UserGroup',on_delete=models.CASCADE)
  roles = models.ManyToManyField('Role')


class UserToken(models.Model):
  user = models.OneToOneField('UserInfo',on_delete=models.CASCADE)
  token = models.CharField(max_length=64)


class UserGroup(models.Model):
  title = models.CharField(max_length=32)


class Role(models.Model):
  title = models.CharField(max_length=32)
# api/views.py
import json

from django.shortcuts import render,HttpResponse
from rest_framework.views import APIView
from rest_framework.request import Request
from rest_framework.versioning import URLPathVersioning
from . import models

##########################################版本和解析器#####################################################

class UserView(APIView):

  def get(self,request,*args,**kwargs):
    #獲取版本
    print(request.version)
    #獲取處理版本的對(duì)象
    print(request.versioning_scheme)
    #獲取瀏覽器訪問(wèn)的url,reverse反向解析
    #需要兩個(gè)參數(shù):viewname就是url中的別名,request=request是url中要傳入的參數(shù)
    #(?P<version>[v1|v2]+)/users/,這里本來(lái)需要傳version的參數(shù),但是version包含在request里面,所有只需要request=request就可以
    url_path = request.versioning_scheme.reverse(viewname='api_user',request=request)
    print(url_path)
    self.dispatch
    return HttpResponse('用戶列表')

# from rest_framework.parsers import JSONParser,FormParser

class PaserView(APIView):
  '''解析'''
  # parser_classes = [JSONParser,FormParser,]
  #JSONParser:表示只能解析content-type:application/json的頭
  #FormParser:表示只能解析content-type:application/x-www-form-urlencoded的頭

  def post(self,request,*args,**kwargs):
    #獲取解析后的結(jié)果
    print(request.data)
    return HttpResponse('paser')


###########################################序列化###########################################################

from rest_framework import serializers

#要先寫一個(gè)序列化的類
class RolesSerializer(serializers.Serializer):
  #Role表里面的字段id和title序列化
  id = serializers.IntegerField()
  title = serializers.CharField()

class RolesView(APIView):
  def get(self,request,*args,**kwargs):
    # 方式一:對(duì)于[obj,obj,obj]
    # (Queryset)
    # roles = models.Role.objects.all()
    # 序列化,兩個(gè)參數(shù),instance:Queryset 如果有多個(gè)值,就需要加 mangy=True
    # ser = RolesSerializer(instance=roles,many=True)
    # 轉(zhuǎn)成json格式,ensure_ascii=False表示顯示中文,默認(rèn)為True
    # ret = json.dumps(ser.data,ensure_ascii=False)

    # 方式二:
    role = models.Role.objects.all().first()
    ser = RolesSerializer(instance=role, many=False)
    ret = json.dumps(ser.data, ensure_ascii=False)
    return HttpResponse(ret)


# class UserInfoSerializer(serializers.Serializer):
#   '''序列化用戶的信息'''
#   #user_type是choices(1,2,3),顯示全稱的方法用source
#   type = serializers.CharField(source="get_user_type_display")
#   username = serializers.CharField()
#   password = serializers.CharField()
#   #group.title:組的名字
#   group = serializers.CharField(source="group.title")
#   #SerializerMethodField(),表示自定義顯示
#   #然后寫一個(gè)自定義的方法
#   rls = serializers.SerializerMethodField()
#
#   def get_rls(self,row):
#     #獲取用戶所有的角色
#     role_obj_list = row.roles.all()
#     ret = []
#     #獲取角色的id和名字
#     #以字典的鍵值對(duì)方式顯示
#     for item in role_obj_list:
#       ret.append({"id":item.id,"title":item.title})
#     return ret


# class UserInfoSerializer(serializers.ModelSerializer):
#   type = serializers.CharField(source="get_user_type_display")
#   group = serializers.CharField(source="group.title")
#   rls = serializers.SerializerMethodField()
#
#   def get_rls(self, row):
#     # 獲取用戶所有的角色
#     role_obj_list = row.roles.all()
#     ret = []
#     # 獲取角色的id和名字
#     # 以字典的鍵值對(duì)方式顯示
#     for item in role_obj_list:
#       ret.append({"id": item.id, "title": item.title})
#     return ret
#
#   class Meta:
#     model = models.UserInfo
#     fields = ['id','username','password','type','group','rls']

# class UserInfoSerializer(serializers.ModelSerializer):
#   class Meta:
#     model = models.UserInfo
#     #fields = "__all__"
#     fields = ['id','username','password','group','roles']
#     #表示連表的深度
#     depth = 1


class UserInfoSerializer(serializers.ModelSerializer):
  group = serializers.HyperlinkedIdentityField(view_name='gp',lookup_field='group_id',lookup_url_kwarg='pk')
  class Meta:
    model = models.UserInfo
    #fields = "__all__"
    fields = ['id','username','password','group','roles']
    #表示連表的深度
    depth = 0


class UserInfoView(APIView):
  '''用戶的信息'''
  def get(self,request,*args,**kwargs):
    users = models.UserInfo.objects.all()
    #這里必須要傳參數(shù)context={'request':request}
    ser = UserInfoSerializer(instance=users,many=True,context={'request':request})
    ret = json.dumps(ser.data,ensure_ascii=False)
    return HttpResponse(ret)


class GroupSerializer(serializers.ModelSerializer):
  class Meta:
    model = models.UserGroup
    fields = "__all__"

class GroupView(APIView):
  def get(self,request,*args,**kwargs):
    pk = kwargs.get('pk')
    obj = models.UserGroup.objects.filter(pk=pk).first()

    ser = GroupSerializer(instance=obj,many=False)
    ret = json.dumps(ser.data,ensure_ascii=False)
    return HttpResponse(ret)



####################################序列化之用戶請(qǐng)求數(shù)據(jù)驗(yàn)證驗(yàn)證####################################

#自定義驗(yàn)證規(guī)則
class GroupValidation(object):
  def __init__(self,base):
    self.base = base

  def __call__(self, value):
    if not value.startswith(self.base):
      message = "標(biāo)題必須以%s為開頭"%self.base
      raise serializers.ValidationError(message)


class UserGroupSerializer(serializers.Serializer):
  title = serializers.CharField(validators=[GroupValidation('以我開頭'),])

class UserGroupView(APIView):
  def post(self,request,*args, **kwargs):
    ser = UserGroupSerializer(data=request.data)
    if ser.is_valid():
      print(ser.validated_data['title'])
    else:
      print(ser.errors)

    return HttpResponse("用戶提交數(shù)據(jù)驗(yàn)證")


##################################################分頁(yè)###################################################

from api.utils.serializsers.pager import PagerSerialiser
from rest_framework.response import Response
from rest_framework.pagination import PageNumberPagination,LimitOffsetPagination,CursorPagination

# #自定義分頁(yè)類1
# class MyPageNumberPagination(PageNumberPagination):
#   #每頁(yè)顯示多少個(gè)
#   page_size = 3
#   #默認(rèn)每頁(yè)顯示3個(gè),可以通過(guò)傳入pager1/?page=2&size=4,改變默認(rèn)每頁(yè)顯示的個(gè)數(shù)
#   page_size_query_param = "size"
#   #最大頁(yè)數(shù)不超過(guò)10
#   max_page_size = 10
#   #獲取頁(yè)碼數(shù)的
#   page_query_param = "page"

#自定義分頁(yè)類2
class MyLimitOffsetPagination(LimitOffsetPagination):
  #默認(rèn)顯示的個(gè)數(shù)
  default_limit = 2
  #當(dāng)前的位置
  offset_query_param = "offset"
  #通過(guò)limit改變默認(rèn)顯示的個(gè)數(shù)
  limit_query_param = "limit"
  #一頁(yè)最多顯示的個(gè)數(shù)
  max_limit = 10


#自定義分頁(yè)類3 (加密分頁(yè))
class MyCursorPagination(CursorPagination):
  cursor_query_param = "cursor"
  page_size = 2   #每頁(yè)顯示2個(gè)數(shù)據(jù)
  ordering = 'id'  #排序
  page_size_query_param = None
  max_page_size = None


class Pager1View(APIView):
  def get(self,request,*args,**kwargs):
    #獲取所有數(shù)據(jù)
    roles = models.Role.objects.all()
    #創(chuàng)建分頁(yè)對(duì)象
    pg = MyCursorPagination()
    #獲取分頁(yè)的數(shù)據(jù)
    page_roles = pg.paginate_queryset(queryset=roles,request=request,view=self)
    #對(duì)數(shù)據(jù)進(jìn)行序列化
    ser = PagerSerialiser(instance=page_roles,many=True)
    return Response(ser.data)
    # return pg.get_paginated_response(ser.data)
# api/utils/serializsers/pager.py

from rest_framework import serializers
from api import models


class PagerSerialiser(serializers.ModelSerializer):
  class Meta:
    model = models.Role
    fields = "__all__"

看完上述內(nèi)容,你們對(duì)如何在Django中使用rest framework實(shí)現(xiàn)分頁(yè)有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI