Django分页器

一.分页器简介

当数据量非常大时, 我们不可能把所有的数据都放在同一页中, 于是就有了分页的概念, 将数据像书一样每一页规定可容纳多少条数据, 运用到Django中的分页组件, 它其实是Django内置的一个类

二.Paginator对象与Page类对象

1.如何得到这两个类对象

  • 导入分页类
from django.core.paginator import Paginator
  • Paginator类对象
# 语法伪代码
paginator = Paginator([要分页的数据],[每页显示条数])
# 示例
paginator = Paginator(shop_list,10)
  • Page类对象
# 语法伪代码
page = paginator.page([第几页])
# 示例
page = paginator.page(2)  # 获取第二页对象

2.Paginator类对象属性和方法

  • 属性
属性名 说明
count 返回数据总条数
num_pages 返回分页之后的总页数
per_page 每页显示的条数
page_range 返回分页后页码的列表
  • 方法
方法名 说明
page(self, number) 返回地number页的page类实例对象

3.Page类对象属性和方法

  • 属性
属性名 说明
number 返回当前页页码
object_list 返回当前页的数据列表
paginator 返回对应的Paginator类对象
  • 方法
方法名 说明
has_previous( ) 判断当前页是否有上一页
has_next( ) 判断当前页是否有下一页
previous_page_number( ) 返回前一页页码
next_page_number( ) 返回下一页页码

三.创建表并插入数据(准备工作)

1.创建模型类

class Shop(models.Model):
    name = models.CharField(max_length=64)
    price = models.DecimalField(max_digits=8,decimal_places=2)
    nums = models.IntegerField(verbose_name='商品剩余')

    def __str__(self):
        return self.name

2.使用for循环批量插入数据

for i in range(1,151):
    models.Shop.objects.create(name=f'商品{i}',price=10+int(f'{i}'),nums=f'{random.randint(1,15)}')

每循环一次就连接一次数据库, 效率低

3.bulk_create( ) : 批量插入数据

import random
shop_list = []
for i in range(1,151):
    book = models.Shop(name=f'商品{i}',price=10+int(f'{i}'),nums=f'{random.randint(1,15)}')
    shop_list.append(book)
models.Shop.objects.bulk_create(shop_list,10)  # 第二个参数是每次插入的条数

可以指定每次插入的条数, 效率高

4.将初始数据渲染到页面

  • page_shop.html 文件
<div class="container">
    <div 
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Django中,分页是一个常见的需求,为了方便处理分页,可以使用Django内置的分页PaginatorPaginator的使用方法很简单,我们可以将一个QuerySet对象或者一个列表作为参数传入Paginator中,然后就可以使用Paginator提供的一些方法来进行分页操作。下面是一个简单的分页小插件的代码: ```python from django.core.paginator import Paginator, EmptyPage, PageNotAnInteger def paginate(objects, page=1, per_page=10): """ 分页小插件 """ paginator = Paginator(objects, per_page) try: paginated_objects = paginator.page(page) except PageNotAnInteger: paginated_objects = paginator.page(1) except EmptyPage: paginated_objects = paginator.page(paginator.num_pages) return paginated_objects ``` 上面的代码定义了一个名为paginate的函数,它接受三个参数: - objects:需要进行分页的对象,可以是一个QuerySet对象或者一个列表。 - page:当前页码,默认为1。 - per_page:每页显示的条目数量,默认为10。 函数中首先使用Paginator来对objects进行分页操作,并使用try/except语句来处理异常情况。如果page参数不是一个整数,则将page设置为1;如果page参数超出了可用的页码范围,则将page设置为最大页码数(paginator.num_pages)。 最后,函数返回一个分页后的对象(paginated_objects),可以在Django模板中使用该对象来渲染分页。 使用该分页小插件的示例代码如下: ```python from django.shortcuts import render from .models import MyModel from .utils import paginate def my_view(request): my_objects = MyModel.objects.all() paginated_objects = paginate(my_objects, request.GET.get('page')) return render(request, 'my_template.html', {'paginated_objects': paginated_objects}) ``` 在上面的代码中,我们首先获取所有的MyModel对象,然后使用paginate函数将其分页,最后将分页后的对象传递给模板进行渲染。 在模板中,可以使用Django内置的分页标签({% for obj in paginated_objects %}、{% if paginated_objects.has_previous %}等)来渲染分页

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

给你骨质唱疏松

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值