先创建表,然后生成批量数据。
在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>
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持小牛知识库。
本文向大家介绍Django的分页器实例(paginator),包括了Django的分页器实例(paginator)的使用技巧和注意事项,需要的朋友参考一下 先导入模块: 分页器paginator 下面的所有方法: 以上这篇Django的分页器实例(paginator)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持呐喊教程。
本文向大家介绍三步实现Django Paginator分页的方法,包括了三步实现Django Paginator分页的方法的使用技巧和注意事项,需要的朋友参考一下 Django提供了一个新的类来帮助管理分页数据,这个类存放在django/core/paginator.py.它可以接收列表、元组或其它可迭代的对象。本文将分三步介绍Django Paginator 分页的实现步骤 一、通过模型创建Su
Django taggit在Django 3.0中不起作用,它在Django-2.2等早期版本中工作良好。因为它依赖于django没有的六个库。3.0中的utils
问题内容: 我正在使用该软件包在列表视图中提供搜索功能。 现在,我还要向该视图添加分页。 我正在尝试将分页与过滤后的查询集结合起来,但是我不知道如何继续。 到目前为止,我已经尝试了以下方法: 问题答案: 要使用Django过滤器并对过滤后的结果进行分页,你可以执行以下操作: 为你的模型创建一个过滤器类: 开 每个对象都有一个包含过滤查询集的属性,如果需要,你甚至可以覆盖它。 我们将对我们的财产进行
已安装django smart selects(pip安装django smart selects),但不适用于django 3.0版。1. 我使用官方安装指南进行了配置。 安装片段 模型。派克 settings.py JQUERY\u URL=True
问题内容: 我已经在pycharm中配置了virtualenv,当使用python manage.py命令时,显示错误: 我应该如何解决,我已经安装了django。 问题答案: 我认为使用django的最佳方法是使用virtualenv,它是安全的,你可以在virtualenv中安装许多应用程序,而这不会影响系统的任何外部空间。vitualenv使用python的默认版本,与在系统中安装virtu