时间:2021-05-22
先创建表,然后生成批量数据。
在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 urlfrom django.contrib import adminfrom app01 import viewsurlpatterns = [ 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>以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
Django提供了一个新的类来帮助管理分页数据,这个类存放在django/core/paginator.py.它可以接收列表、元组或其它可迭代的对象。本文将分三
Django提供了一个新的类来帮助你管理分页数据,这个类存放在django/core/paginator.py.它可以接收列表、元组或其它可迭代的对象。clas
Django中提供了一个类Paginator专门用来管理和处理分页数据,所以我们在使用之前先导入好相应的类,,另外这里我们也导入了待会会用到的处理异常的两个类E
django中有自带的分页模块Paginator,想Paginator提供对象的列表,就可以提供每一页上对象的方法。这里的话不讲解Paginator,而是自定义
使用PyCharm学习Django框架,从项目的主urls中导入app中的views的时候,导入的包中下面有红线报错,但是却能正常使用。要是这样也就没什么事了,