先创建表,然后生成批量数据。
在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/" 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/" rel="external nofollow" >{{ num }}</a></li>
{% endfor %}
{% if book_list.has_next %}
<li><a href="/showBooks/" rel="external nofollow" >下一页</a></li>
{% else %}
<li class="disabled"><a href="#" rel="external nofollow" rel="external nofollow" >下一页</a></li>
{% endif %}
</ul>
</body>
</html>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
暂无“django的分页器Paginator 从django中导入类”评论...
P70系列延期,华为新旗舰将在下月发布
3月20日消息,近期博主@数码闲聊站 透露,原定三月份发布的华为新旗舰P70系列延期发布,预计4月份上市。
而博主@定焦数码 爆料,华为的P70系列在定位上已经超过了Mate60,成为了重要的旗舰系列之一。它肩负着重返影像领域顶尖的使命。那么这次P70会带来哪些令人惊艳的创新呢?
根据目前爆料的消息来看,华为P70系列将推出三个版本,其中P70和P70 Pro采用了三角形的摄像头模组设计,而P70 Art则采用了与上一代P60 Art相似的不规则形状设计。这样的外观是否好看见仁见智,但辨识度绝对拉满。
更新动态
2025年11月06日
2025年11月06日
- 小骆驼-《草原狼2(蓝光CD)》[原抓WAV+CUE]
- 群星《欢迎来到我身边 电影原声专辑》[320K/MP3][105.02MB]
- 群星《欢迎来到我身边 电影原声专辑》[FLAC/分轨][480.9MB]
- 雷婷《梦里蓝天HQⅡ》 2023头版限量编号低速原抓[WAV+CUE][463M]
- 群星《2024好听新歌42》AI调整音效【WAV分轨】
- 王思雨-《思念陪着鸿雁飞》WAV
- 王思雨《喜马拉雅HQ》头版限量编号[WAV+CUE]
- 李健《无时无刻》[WAV+CUE][590M]
- 陈奕迅《酝酿》[WAV分轨][502M]
- 卓依婷《化蝶》2CD[WAV+CUE][1.1G]
- 群星《吉他王(黑胶CD)》[WAV+CUE]
- 齐秦《穿乐(穿越)》[WAV+CUE]
- 发烧珍品《数位CD音响测试-动向效果(九)》【WAV+CUE】
- 邝美云《邝美云精装歌集》[DSF][1.6G]
- 吕方《爱一回伤一回》[WAV+CUE][454M]
