1.分页:
Paginator对象
Page对象
2.Paginator:
class Paginator(object_list, per_page, orphans=0, allow_empty_first_page=True)
Required arguments:
- object_list
- per_page  每页显示多少条
Optional arguments:
- orphans
- allow_empty_Òrst_page
属性:
- Paginator.count 所有页面的objects总数
- Paginator.num_pages 页面总数
- Paginator.page_range 页码的范围,从1开始,例如[1, 2, 3, 4]
方法:
- Paginator.page(number) 返回一个page对象,number, 当前显示的是第几页
 
3.Page:
class Page(object_list, number, paginator)
属性:
- Page.object_list 当前页面的对象列表
- Page.number 当前页的序号,从1开始
- Page.paginator Paginator对象
方法
- Page.has_next() 如果有下一页,返回True
- Page.has_previous() 如果有上一页,返回 True
- Page.has_other_pages() 如果有上一面或下一页,返回True
- Page.next_page_number() 返回下一页的页码。如果不存在,抛出InvalidPage异常
- Page.previous_page_number() 返回上一页的页码。如果不存在,抛出InvalidPage异常
- Page.start_index() 返回当前页上的第一个对象,相对于分页列表的所有对象的序号
- Page.end_index() 返回当前页上的最后一个对象,相对于分页列表的所有对象的序号

1.小案例:一次建立1000个用户:
(python36env) [vagrant@CentOS7 devops]$ python manage.py shell

In [1]: from django.contrib.auth.models import User

In [2]: username = "rock"

In [3]: for i in range(1000):
...: name = "{}_{}".format(username, i)
...: User.objects.create_user(name, "{}@51reboot.com".format(name), "123456")

2.查询用户

In [2]: User.objects.all()   查询出所有用户/只是不会全列完

In [3]: User.objects.all()[:10] 前十条

In [4]: queryset = User.objects.all()[:10]  -->1.取数据

In [5]: queryset.values()   这样就可把所有的数据转换出来如下图

In [10]: queryset.values("username", "email")    --->2.取部分字段
<QuerySet [{'username': 'devops', 'email': '123@qq.com'}, {'username': 'rock', 'email': 'rock@51reboot.com'}, {'username': 'rock_0', 'email': 'rock_0@51reboot.com'},。。。。。}]>

In [11]: list(queryset.values("username", "email"))   --->3.转换成json(这样的数据可直接给httpresponse对象)再返回给浏览器
Out[11]:
[{'username': 'devops', 'email': '123@qq.com'},
{'username': 'rock', 'email': 'rock@51reboot.com'},
{'username': 'admin', 'email': 'admin@51reboot.com'},
{'username': 'rock_0', 'email': 'rock_0@51reboot.com'},

3.我要的是在前端传第几页?page参数就能返回第几页的数据:

1.拿到page => str类型  要转int

2.获取数据:

  User.objects.all()

3.对数据进行处理,分页--根据传的page值来计算切片的开头和结尾:

  queryset = User.objects.all()[start:end]

4.转json:

  ret = list(queryset.values("id","username","email"))

5.返回httpresponse对象:

views.py中:

from django.views import View
class MyView(View):
def get(self,request,*args,**kwargs):
per = 10
try:#转的过程可能会出错如果出错就让page等于1
page = int(request.GET.get("page",1))
except:
page = 1
end = page * 10
start = end - 10
queryset = User.objects.all()[start:end]
data = list(queryset.values("id","username","email"))
return JsonResponse(data, safe=False)

dashboard/urls.py中:

from django.conf.urls import include, url
from .views import MyView
urlpatterns = [
url(r'^hello/', MyView.as_view()),
]

启动效果如图:

4.分页面展示出提示搜索结果有多少条记录/共有多少页/下上一页/首页/尾页---paginator对象

https://devdocs.io/   神奇的文档网,可以在此参考

(python36env) [vagrant@CentOS7 devops]$ python manage.py shell
In [13]: queryset = User.objects.all()
In [14]: from django.core.paginator import Paginator
In [15]: paginator = Paginator(queryset, 10) 实例化对象
In [16]: paginator.count 总共有多少条
Out[16]: 1003
In [17]: paginator.num_pages 总共有多少页
Out[17]: 101
In [18]: paginator.page_range 页码范围
Out[18]: range(1, 102)

In [19]: page = paginator.page(10)  #实例化page对象当前页是第十页

In [20]: page.number
Out[20]: 10

In [21]: page.next_page_number()
Out[21]: 11

七.数据分页原理,paginator与page对象的更多相关文章

  1. 15 ~ express ~ 用户数据分页原理和实现

    一,在后台路由 /router/admin.js 中 1,限制获取的数据条数 : User.find().limit(Number) 2,忽略数据的前(Number)条数据 : skip(Number ...

  2. ThinkPHP数据分页Page.class.php

    获取分页类 ThinkPHP提供了数据分页的扩展类库Page,能够在http://www.thinkphp.cn/extend/241.html下载,或者下载官方的完整扩展包(http://www.t ...

  3. 在pycharm中批量插入表数据、分页原理、cookie和session介绍、django操作cookie

    昨日内容回顾 ajax发送json格式数据 ''' 1. urlencoded 2. form-data 3. json ''' 1. ajax $.ajax({ data: JSON.stringi ...

  4. Mybatis的分页插件PageHelp:Page对象中的pageSize等属性无法序列化,无法转换为json字符串

    Page<User> page = new Page<>();        User user = new User();        user.setAge(20);   ...

  5. django orm 分页(paginator)取数据出现警告manage.py:1: UnorderedObjectListWarning: Pagination may yield inconsistent results with an unordered object_list: <class 'sign.models.Guest'> QuerySet.

    使用django的orm做分页(Paginator)时出现了下面的警告 In [19]: p=Paginator(guest_list,2) manage.py:1: UnorderedObjectL ...

  6. 使用Puppeteer进行数据抓取(二)——Page对象

    page对象是puppeteer最常用的对象,它可以认为是chrome的一个tab页,主要的页面操作都是通过它进行的.Google的官方文档详细介绍了page对象的使用,这里我只是简单的小结一下. 客 ...

  7. 重新学习MySQL数据库3:Mysql存储引擎与数据存储原理

    重新学习Mysql数据库3:Mysql存储引擎与数据存储原理 数据库的定义 很多开发者在最开始时其实都对数据库有一个比较模糊的认识,觉得数据库就是一堆数据的集合,但是实际却比这复杂的多,数据库领域中有 ...

  8. Django——分页功能Paginator

    Django分页功能----Paginator Paginator所需参数: Paginator(object_list,per_page) Paginator常用属性: per_page: 每页显示 ...

  9. Django分页组件——Paginator

    from django.core.paginator import Paginator #导入Paginator objects = ['john','paul','george','ringo',' ...

随机推荐

  1. Java实现 LeetCode 638 大礼包(阅读理解题,DFS)

    638. 大礼包 在LeetCode商店中, 有许多在售的物品. 然而,也有一些大礼包,每个大礼包以优惠的价格捆绑销售一组物品. 现给定每个物品的价格,每个大礼包包含物品的清单,以及待购物品清单.请输 ...

  2. 第九届蓝桥杯JavaA组省赛真题

    解题代码部分来自网友,如果有不对的地方,欢迎各位大佬评论 题目1.分数 题目描述 1/1 + 1/2 + 1/4 + 1/8 + 1/16 + - 每项是前一项的一半,如果一共有20项, 求这个和是多 ...

  3. java实现第三届蓝桥杯源码变换

    源码变换 这道题因为有一些html语言在编写的时候不会显示出来,所以就用代码格式把题目写出来 [编程题](满分22分) 超文本标记语言(即HTML),是用于描述网页文档的一种标记语言. HTML通过文 ...

  4. 1.4 Spring 依赖注入(DI)和控制反转(IOC)详解

    自己开发了一个股票智能分析软件,功能很强大,需要的点击下面的链接获取: https://www.cnblogs.com/bclshuai/p/11380657.html 1.1  Spring 依赖注 ...

  5. Python3 源码阅读 - 垃圾回收机制

    Python的垃圾回收机制包括了两大部分: 引用计数(大部分在 Include/object.h 中定义) 标记清除+隔代回收(大部分在 Modules/gcmodule.c 中定义) 1. 引用计数 ...

  6. CSS学习:overflow:hidden解决溢出,坍塌,清除浮动

    overflow:hidden是overflow属性的一个神奇用法,它可以帮助我们隐藏溢出的元素,清除浮动和解除坍塌. CSS样式: .container{ background-color: bla ...

  7. @atcoder - AGC008E@ Next or Nextnext

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 给定一个长度为 N 的序列 a,问有多少排列 p,满足对于每一个 ...

  8. PAT 1043 Is It a Binary Search Tree (25分) 由前序遍历得到二叉搜索树的后序遍历

    题目 A Binary Search Tree (BST) is recursively defined as a binary tree which has the following proper ...

  9. 深入理解Java虚拟机学习笔记(三)-----类文件结构/虚拟机类加载机制

    第6章 类文件结构 1. 无关性 各种不同平台的虚拟机与所有平台都统一使用的程序存储格式——字节码(即扩展名为 .class 的文件) 是构成平台无关性的基石. 字节码(即扩展名为 .class 的文 ...

  10. 使用IntelliJ/Eclipse生成类图

    IntelliJ可以安装一个免费的pugins - Code Iris. PlantUML 在Eclipse中 - ObjectAidPapyrusEclipse Modeling Tools 查看原 ...