Django学习之分页器

本文介绍了如何在Django中实现数据批量插入和分页显示。首先讲解了Django的批量插入数据方法,提高了数据库操作效率。接着,阐述了数据显示和分页器的使用,通过url参数控制页面显示内容。最后讨论了分页效果的优化,当页数过多时,只显示部分页码以提高用户体验。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1>数据批量插入

    网站内容记录很多,必然要分页显示,比如100条数据,每页显示10条,那么总共就有10页,点击对应的页签,则

    显示相应的内容,实现这个需求之前,我们先看怎么对mysql批量插入数据,

    一个方法,for循环再插入,如下,

    for i in range(1, 101):
        Book.objects.create(title='book_%s'%i, price=i**2)

   但这个方法始终都是“一条一条”插入的,翻译成sql语句其实就是有100条insert语句,很明显,效率不是太高,

   其实dajngo中自带一个批量插入的语法,可以把循环出来的数据一次性插入数据库,就相当于一条sql语句实现了

  数据的插入,效率明显高多了,推荐大家使用这种方法,如下:

    

2>数据显示

    

3>分页显示效果

    先说几个概念,导入分页器模块,加粗的都是分页器经常使用的方法

    from django.core.paginator import Paginator
    book_obj = Book.objects.all()<
Django中,分页是一个常见的需求,为了方便处理分页,可以使用Django内置的分页器Paginator。 Paginator的使用方法很简单,我们可以将一个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 %}等)来渲染分页器
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值