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
0
投稿
猜你喜欢
- 产品使用者可分为三个类别,分别是:初级用户、中级用户、高级用户。这三个类别分别代表了用户使用产品的三个阶段,其中初级用户是占最大比例的,中级
- 一、查询条件精确,针对有参数传入情况 二、SQL逻辑执行顺序 FROM-->JOIN-->WHERE-->GROUP--&
- 具体特征如下: 1、通过模板实现俄文正常。 2、通过后台数据库生成的静态俄文信息,后台显示正常, 前台乱码。 3、英文正常。 和该主题相关的
- 本文实例讲述了Python多线程原理与用法。分享给大家供大家参考,具体如下:先来看个栗子:下面来看一下I/O秘籍型的线程,举个栗子——爬虫,
- 这篇文章主要介绍了python连接字符串过程详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以
- 自个儿闲的发疯画几个老鼠的表情,送女朋友。。HOHO。经常欺负人。哎。其实被欺负是一种幸福。工作以美国时间为主,所以白天睡到晚上。我不傻,真
- 为了防止机器人频繁登陆网站或者破坏分子恶意登陆,很多用户登录和注册系统都提供了图形验证码功能。验证码(CAPTCHA)是“Completel
- 这个是JS控制图片滚动的效果,当鼠标结果新闻标题时开始滚动到对应的图片,可以作为图片新闻。效果图:<!DOCTYPE HTML PUB
- Python 模块EasyGui详细介绍前言:在Windows想用Python开发一些简单的界面,所以找到了很容易上手的EasyGui库。下
- github指路作业要求友情提示ldw老师给の友情提示(虽然感觉也还好/dbq其实还挺有用的)课上讲的例子是图片展示器(能够实现打开图片+镜
- 假设mysql安装在c:盘,mysql数据库的用户名是root,密码是123456,数据库名是database_name,在d:盘根目录下面
- 1.max取最大值函数max() 方法返回给定参数的最大值,参数可以为序列。lis = [1,2,3,-4]print(max(lis))
- <%@ Language=VBScript %><HTML><HEAD>
- 下面列出Python正则表达式的几种匹配用法,具体内容如下所示:此外,关于正则的一切http://deerchao.net/tutorial
- 众所周知,python文件读取文件的时候所支持的newlines(即换行符),是指定的。这一点不管是从python的doucuments上还
- 创建一个优秀的可视化图表的关键在于引导读者,让他们能理解图表所讲述的故事。在一些情况下,这个故事可以通过纯图像的方式表达,不需要额外添加文字
- 在python类当中,经常会遇到@classmethod和@staticmethod这两个装饰器,那么到底它们的区别和作用是啥子呢?具体来看
- 这一版,对虹软的功能进行了一些封装,添加了人脸特征比对,比对结果保存到文件,和从文件提取特征进行比对,大体功能基本都已经实现,可以进行下一步
- 布尔表示两值之一:True 或 False。 布尔值在编程中,通常需要知道表达式是 True 还是 False。可以计算 Python 中的
- 1. str.format 的引入在 Python 中,我们可以使用 + 来连接字符串,在简单情况下这种方式能够很好的工作。但是当我们需要进