七.数据分页原理,paginator与page对象
1.分页:
Paginator对象
Page对象
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对象的更多相关文章
- 15 ~ express ~ 用户数据分页原理和实现
一,在后台路由 /router/admin.js 中 1,限制获取的数据条数 : User.find().limit(Number) 2,忽略数据的前(Number)条数据 : skip(Number ...
- ThinkPHP数据分页Page.class.php
获取分页类 ThinkPHP提供了数据分页的扩展类库Page,能够在http://www.thinkphp.cn/extend/241.html下载,或者下载官方的完整扩展包(http://www.t ...
- 在pycharm中批量插入表数据、分页原理、cookie和session介绍、django操作cookie
昨日内容回顾 ajax发送json格式数据 ''' 1. urlencoded 2. form-data 3. json ''' 1. ajax $.ajax({ data: JSON.stringi ...
- Mybatis的分页插件PageHelp:Page对象中的pageSize等属性无法序列化,无法转换为json字符串
Page<User> page = new Page<>(); User user = new User(); user.setAge(20); ...
- 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 ...
- 使用Puppeteer进行数据抓取(二)——Page对象
page对象是puppeteer最常用的对象,它可以认为是chrome的一个tab页,主要的页面操作都是通过它进行的.Google的官方文档详细介绍了page对象的使用,这里我只是简单的小结一下. 客 ...
- 重新学习MySQL数据库3:Mysql存储引擎与数据存储原理
重新学习Mysql数据库3:Mysql存储引擎与数据存储原理 数据库的定义 很多开发者在最开始时其实都对数据库有一个比较模糊的认识,觉得数据库就是一堆数据的集合,但是实际却比这复杂的多,数据库领域中有 ...
- Django——分页功能Paginator
Django分页功能----Paginator Paginator所需参数: Paginator(object_list,per_page) Paginator常用属性: per_page: 每页显示 ...
- Django分页组件——Paginator
from django.core.paginator import Paginator #导入Paginator objects = ['john','paul','george','ringo',' ...
随机推荐
- Java实现蓝桥杯 算法提高 八皇后 改
**算法提高 8皇后·改** 时间限制:1.0s 内存限制:256.0MB 提交此题 问题描述 规则同8皇后问题,但是棋盘上每格都有一个数字,要求八皇后所在格子数字之和最大. 输入格式 一个8*8的棋 ...
- Java实现 蓝桥杯 算法训练 求平方和
试题 算法训练 求平方和 问题描述 请用函数重载实现整型和浮点习型的两个数的平方和计算 输入格式 测试数据的输入一定会满足的格式. 2 2(2行2列,第1行整型,第2行浮点型) 输出格式 要求用户的输 ...
- Java实现 LeetCode 236 二叉树的最近公共祖先
236. 二叉树的最近公共祖先 给定一个二叉树, 找到该树中两个指定节点的最近公共祖先. 百度百科中最近公共祖先的定义为:"对于有根树 T 的两个结点 p.q,最近公共祖先表示为一个结点 x ...
- Android Button的四种点击事件
bta1.setOnClickListener(new View.OnClickListener() { @Override public void onClick(View v) { Toast.m ...
- hackrf 输出功率测试
使用PortaPack H1的话筒发射功能测试: 144M :8dbm 430M:6dbm 950M:6dbm 1545.42M:0.5dbm 7.42M:18.5dbm 14.2M:16.3dbm
- [Google Guava] 强大的集合工具类:java.util.Collections中未包含的集合工具
转载的,有问题请联系我 原文链接 译文链接 译者:沈义扬,校对:丁一 尚未完成: Queues, Tables工具类 任何对JDK集合框架有经验的程序员都熟悉和喜欢java.util.Collecti ...
- 有趣的 Canvas
canvas动画狗:https://www.jianshu.com/p/7873307147d5
- [ARC101B]Median of Medians
题目 点这里看题目. 分析 看到中位数,当然会想到二分答案. 考虑检查答案.自然,我们需要找出中位数小于二分值\(k\)的区间的个数.考虑构造一个\(b\): \[b_i=(-1)^{[a ...
- PowerApps Component Framework PCF 部署
PowerApps PCF 可以满足复杂的功能, 我们可以使用PCF来创建复杂的PowerApps. 这里附上微软的package code componet 教程(https://docs.micr ...
- (八)跑完用例后通过maven发送邮件
邮件类: package config; import com.sun.mail.util.MailSSLSocketFactory; import org.apache.log4j.Logger; ...