django的分页器Paginator 从django中导入类
作者:谷子的 发布时间:2022-02-07 04:24:29
标签:django,分页器,paginator,导入,类
先创建表,然后生成批量数据。
在models文件里
from django.db import models
# Create your models here.
class Book(models.Model):
name = models.CharField(max_length=32)
price = models.DecimalField(max_digits=5,decimal_places=2)
然后执行python manage.py makemigrations ,python migrate 生成数据库。把数据库从左边拉到右边,
在url里创建showBooks视图函数API,
from django.conf.urls import url
from django.contrib import admin
from app01 import views
urlpatterns = [
url(r'^admin/', admin.site.urls),
url(r'^index/', views.index),
url(r'^ajaxHandle/', views.ajaxHandle),
url(r'^showBooks/', views.showBooks),-------
在views文件中创建showBooks 函数,批量导入数据,用bulk_create()
从django中导入Paginstor类,用对象调用方法,
def showBooks(requests):
#批量导入数据bulk_create()方法
# book_list=[]#里面存一个个对象
# for i in range(100):
# book_list.append(Book(name="book%s"%i,price=2+i+2))
#
# Book.objects.bulk_create(book_list)
book_list_all = Book.objects.all()
#分页器Paginator,是导入了一个类,在用实列出来的对象调用方法,
from django.core.paginator import Paginator,EmptyPage,PageNotAnInteger
#book_list_all 是要被分页的对象,第二个参数,是每页显示的条数
p = Paginator(book_list_all,20)# p就是每页的对象,
p.count #数据总数
p.num_pages #总页数
p.page_range#[1,2,3,4,5],得到页码,动态生成,
page_num = requests.GET.get("page")#以get的方法从url地址中获取
#如果输错了页码,
try:
book_list = p.page(page_num)#括号里的是页数,显示指定页码的数据,动态显示数据,所以不能写死了
except PageNotAnInteger:#如果输入页码错误,就显示第一页
book_list = p.page(1)
except EmptyPage:#如果超过了页码范围,就把最后的页码显示出来,
book_list = p.page(p.num_pages)
return render(requests,"showBooks.html",locals())
数据库生成数据
在templates 创建showBooks页面,把数据库数据渲染出来
{% load staticfiles %}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<link rel="stylesheet" href="{% static 'bootstrap/css/bootstrap.css' %}" rel="external nofollow" >
</head>
<body>
<ul>
{#request 也可以在这里渲染出来#}
{% for book in book_list %}
<li>{{ book.id }}     {{ book.name }}     {{ book.price }}</li>
{% endfor %}
</ul>
<ul class="pagination">
{% if book_list.has_previous %}
<li><a href="/showBooks/?page={{ book_list.previous_page_number }}" rel="external nofollow" >上一页</a></li> ---直接使用方法,上一页,
{% else %}
<li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" >上一页</a></li>
{% endif %}
{% for num in p.page_range %}
<li><a href="/showBooks/?page={{ num }}" rel="external nofollow" >{{ num }}</a></li>
{% endfor %}
{% if book_list.has_next %}
<li><a href="/showBooks/?page={{ book_list.next_page_number }}" rel="external nofollow" >下一页</a></li>
{% else %}
<li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" >下一页</a></li>
{% endif %}
</ul>
</body>
</html>
来源:https://www.cnblogs.com/gyh04541/p/7956109.html


猜你喜欢
- 用XMlhttp生成html页面,相关函数如下:<% ’定义xmlhttp function Get
- 实例引入我们知道 Python 是一种动态语言,在声明一个变量时我们不需要显式地声明它的类型,例如下面的例子:a = 2print('
- python join 和 split方法简单的说是:join用来连接字符串,split恰好相反,拆分字符串的。.join()join将 容
- 设计中文网站的朋友都会有这样的体会,Dreamweaver功能虽然强大,但要按照中文的行文习惯实现每个
- 三遍记忆,让你记住海量素材的准确位置和用途,提高其可用性.这仅仅是一个示意图.在以往的日子里,我做到了只要脑袋里冒出一个想法,立刻就能知道我
- 如下所示:import pandas as pdpath='F:/python/python数据分析与挖掘实战/图书配套数据、代码/
- 如何做一个密码“生成器”?randompassword.asp<% Dim i, intNum,&nbs
- 特点:1.图片预载入,载入后再显示。意图一次呈现,不会让一块一块下载破坏你的页面,绝佳的用户体验,颠覆传统的浏览器呈现图片的处理方式(需要后
- 1. Golint(1)安装golintgit clone https://github.com/golang/lint.git
- 本文介绍在Anaconda环境下,安装Python中栅格、矢量等地理数据处理库GDAL的方法。  需要注
- PHP Warning: strtotime(): It is not safe to rely on the system's t
- 本文实例为大家分享了Android九宫格图片展示的具体代码,供大家参考,具体内容如下一.知识点总结1. 卷积神经网络出
- 本文实例讲述了Django框架实现的简单分页功能。分享给大家供大家参考,具体如下:前面一篇《Django开发的简易留言板》写了个简单的留言板
- 环境 python3.0工具 pycharm谷歌插件chromedriver程序执行方法from selenium import webdr
- 前言一个非常神秘的魔术方法。这个方法非常不起眼,用途狭窄,我几乎从未注意过它,然而,当发现它可能是上述“定律”的唯一例外情况时,我认为值得再
- 本文分享下自己平时积累的一些实用性较高的js方法,供大家指点和评价。本想分篇介绍,发现有点画蛇添足。整理了下也没多少拿得出手的方法,自然有一
- 一、算术运算符运算符+-*/%**(幂)求次方//(取整除,向下取整)如:9//2 =4二、比较运算符运算符==!=<>(不等于
- 注释用于说明代码实现的功能、采用的算法、代码的编写者以及创建和修改的时间等信息。注释是代码的一部分,注释起到了对代码补充说明的作用。Pyth
- 今天做一个超简单的无损放大图片的程序,原理很简单JPG原理:读取原图片的像素点的RGB颜色值并保存到文件内,然后将原图进行翻倍放大,在放大的
- 相信每一个 javascript 学习者,都会去了解 JS 的各种基本数据类型,数组就是数据的组合,这是一个很基本也十分简单的概念,他的内容