python-django_分页器_批量插入数据_分页器的使用方法

Django 分页器

分页器

1. 分页器组件介绍

1. 项目数据量大了以后,比如涉及到分页,一页一页的加载显示
2. django中分页器组件,把分页常用的东西,封装到一个类中
3. 实例化得到一个对象,对象里有属性和方法
4. 在页面显示分页数据,需要用到Django分页器组件
	from django.core.paginator import Paginator

2. 批量插入数据

def index(request):
    # 批量插入数据
    # 方式一
    for i in range(100):
        models.Book.objects.create(name='书籍%s'%i,price=i+1) # 写了100次数据库
	# 再将所有的数据查询并展示到前端页面
    book_queryset = models.Book.objects.all()
    
    # 方式二
    ll = []
    for i in range(100):
        book = models.Book(name='书籍%s' % i, price=i + 1)
        ll.append(book)
    # bulk_create() 批量插入数据
    models.Book.objects.bulk_create(ll, 10)
    """
    当你想要批量插入数据的时候 使用orm给你提供的bulk_create能够大大的减少操作时间
    :param request: 
    :return: 
    """
    return render(request, 'index.html',locals())

3. 分页器简单使用

# 1. from django.core.paginator import Paginator
    # Paginator对象:paginator = Paginator(user_list, 10)
        per_page: 每页显示条目数量
        count:    数据总个数
        num_pages:总页数
        page_range:总页数的索引范围,如: (1,10),(1,200)
        page:     page对象    
    # page对象:page=paginator.page(1)
        has_next              是否有下一页
        next_page_number      下一页页码
        has_previous          是否有上一页
        previous_page_number  上一页页码
        object_list           分页之后的数据列表
        number                当前页
        paginator             paginator对象

# 2. Paginator对象的属性和方法
    book_list=models.Book.objects.all()
    # 实例化得到对象
    # 第一个参数:要分页的数据,book_list
    # 第二个参数:没有条数
    paginator=Paginator(book_list,10)
    # Paginator对象的属性和方法
    print(paginator.per_page)   # 每页显示的条数
    print(paginator.count)      # 总条数,总共要分页多少条数据
    print(paginator.num_pages)  # 总页码数
    print(paginator.page_range) # 页码的生成器 [1,2,3,4,5,6,7,8,9,10]
    
# 3. Page对象的属性和方法
    # Page类 的对象
    page=paginator.page(2)   # 第二页的对象
    # 每一页的对象,属性和方法
    print(page.has_next())             # 有没有下一页
    print(page.next_page_number())     # 下一页页码
    print(page.has_previous())         # 是否有上一页
    print(page.previous_page_number()) # 上一页页面 (当前页如果是第一页,没有上一页)
    print(page.object_list)            # 当前页的所有数据
    print(page.number)                 # 当前页的页码数   
    
# 4. 表模型中默认以id排序
    class Meta:
        ordering=('id', )  # 默认以id排序

4. 视图

def index(request):
    # 需要的第三个参数
    page_num_int=int(request.GET.get('page',1))
    book_list = models.Book.objects.all()
    paginator = Paginator(book_list, 10)

    # 需要的第一个参数:页码的生成器 [1,2,3,4,5,6,7,8,9,10]
    page_range = paginator.page_range
    
    # 需要的第二个参数,去到某一页的page对象
    page = paginator.page(page_num_int)
    return render(request, 'index.html', {'page_range':page_range,'page':page,'page_num_int':page_num_int})

5. 模板

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
    <title>Title</title>
</head>
<body>
<div class="container-fluid">
    <div class="row">
        <div class="col-md-6 col-md-offset-3">
            <table class="table">
                <thead>
                <tr>
                    <th>id</th>
                    <th>名字</th>
                    <th>价格</th>
                </tr>
                </thead>
                <tbody>

                {% for book in page.object_list %}
                    <tr>
                        <td>{{ book.id }}</td>
                        <td>{{ book.name }}</td>
                        <td>{{ book.price }}</td>
                    </tr>
                {% endfor %}
                </tbody>
            </table>

            <div class="text-center">
                <nav aria-label="Page navigation">
                    <ul class="pagination">

                        {% if page.has_previous %}
                            <li>
                                <a href="/?page={{ page.previous_page_number }}" aria-label="Previous">
                                    <span aria-hidden="true">&laquo;</span>
                                </a>
                            </li>
                        {% else %}
                            <li class="disabled">
                                <a href="" aria-label="Previous">
                                    <span aria-hidden="true">&laquo;</span>
                                </a>
                            </li>
                        {% endif %}

                        {% for page_num in page_range %}
                            {% if page_num_int == page_num %}
                                <li class="active"><a href="/?page={{ page_num }}">{{ page_num }}</a></li>
                            {% else %}
                                <li><a href="/?page={{ page_num }}">{{ page_num }}</a></li>
                            {% endif %}

                        {% endfor %}

                        {% if page.has_next %}
                            <li>
                                <a href="/?page={{ page.next_page_number }}" aria-label="Next">
                                    <span aria-hidden="true">&raquo;</span>
                                </a>
                            </li>
                        {% else %}
                            <li class="disabled">
                                <a href="" aria-label="Next">
                                    <span aria-hidden="true">&raquo;</span>
                                </a>
                            </li>
                        {% endif %}
                    </ul>
                </nav>
            </div>
        </div>
    </div>
</div>
</body>
</html>

6. 分页器的进阶使用

# 最多显示前5 后5 和当前,总共11个页码,如果少于11,全部显示出来

# 逻辑分析 
	显示左5,右5,总共11个页,
    1. 如果总页码大于11
        1.1 if 当前页码减5小于1,要生成112的列表(顾头不顾尾,共11个页码)
            page_range=range(1,12)
        1.2 elif 当前页码+5大于总页码,生成当前页码减10,到当前页码加1的列表(顾头不顾尾,共11个页码)
            page_range=range(paginator.num_pages-10,paginator.num_pages+1)
        1.3 else 生成当前页码-5,到当前页码+6的列表
            page_range=range(current_page_num-5,current_page_num+6)
    2. 其它情况,生成的列表就是pageinator的page_range
        page_range=paginator.page_range

7. 视图

def index(request):
    # 需要的第三个参数
    page_num_int = int(request.GET.get('page', 1))
    book_list = models.Book.objects.all()
    paginator = Paginator(book_list, 1)

    # 需要的第一个参数:页码的生成器 [1,2,3,4,5,6,7,8,9,10]
    # page_range = paginator.page_range
    if paginator.num_pages > 11:
        # 当前条件符合了以后,有三种情况
        if page_num_int - 5 < 1:
            page_range = range(1, 11)
        elif page_num_int + 5 > paginator.num_pages:
            page_range = range(paginator.num_pages - 10, paginator.num_pages + 1)
        else:
            page_range = range(page_num_int - 5, page_num_int + 5)
    else:
        page_range = paginator.page_range
        
    # 需要的第二个参数,去到某一页的page对象
    page = paginator.page(page_num_int)
    return render(request, 'index.html', {'page_range': page_range, 'page': page, 'page_num_int': page_num_int})

8. 模板

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <link rel="stylesheet" href="/static/bootstrap/css/bootstrap.min.css">
    <title>Title</title>
</head>
<body>
<div class="container-fluid">
    <div class="row">
        <div class="col-md-6 col-md-offset-3">
            <table class="table">
                <thead>
                <tr>
                    <th>id</th>
                    <th>名字</th>
                    <th>价格</th>
                </tr>
                </thead>
                <tbody>
                {% for book in page.object_list %}
                    <tr>
                        <td>{{ book.id }}</td>
                        <td>{{ book.name }}</td>
                        <td>{{ book.price }}</td>
                    </tr>
                {% endfor %}
                </tbody>
            </table>

            <div class="text-center">
                <nav aria-label="Page navigation">
                    <ul class="pagination">
                        {% if page.has_previous %}
                            <li>
                                <a href="/?page={{ page.previous_page_number }}" aria-label="Previous">
                                    <span aria-hidden="true">&laquo;</span>
                                </a>
                            </li>
                        {% else %}
                            <li class="disabled">
                                <a href="" aria-label="Previous">
                                    <span aria-hidden="true">&laquo;</span>
                                </a>
                            </li>
                        {% endif %}

                        {% for page_num in page_range %}
                            {% if page_num_int == page_num %}
                                <li class="active"><a href="/?page={{ page_num }}">{{ page_num }}</a></li>
                            {% else %}
                                <li><a href="/?page={{ page_num }}">{{ page_num }}</a></li>
                            {% endif %}

                        {% endfor %}
                        
                        {% if page.has_next %}
                            <li>
                                <a href="/?page={{ page.next_page_number }}" aria-label="Next">
                                    <span aria-hidden="true">&raquo;</span>
                                </a>
                            </li>
                        {% else %}
                            <li class="disabled">
                                <a href="" aria-label="Next">
                                    <span aria-hidden="true">&raquo;</span>
                                </a>
                            </li>
                        {% endif %}
                    </ul>
                </nav>

            </div>
        </div>
    </div>
</div>
</body>
</html>

9. 自定义分页器

"""
django也有内置的分页器模块 但是功能较少代码繁琐不便于使用
所以我们自己自定义我们自己的分页器
"""
1. queryset对象是直接切片操作的
2. 用户到底要访问哪一页 如何确定	url?page=1
	current_page = request.GET.get('page',1)
    # 获取到的数据都是字符串类型 你需要注意类型转换
3. 自己规定每页展示多少条数据
	per_page_num = 10
4. 切片的起始位置和终止位置
	start_page = (current_page - 1* per_page_num
    end_page = current_page * per_page_num
    # 利用简单找规律 找出上述四个参数的规律
5. 当前数据的总条数
	  book_queryset.count()
6. 如何确定总共需要多少页才能展示完所有的数据
	  # 利用python内置函数divmod()
      page_count, more = divmod(all_count,per_page_num)
      if more:
        page_count += 1
7. 前端模版语法是没有range功能的
	# 前端代码不一定非要在前端书写 也可以在后端生成传递给页面
8. 针对需要展示的页码需要你自己规划好到底展示多少个页码
	# 一般情况下页码的个数设计都是奇数(符合审美标准)  11个页码
      当前页减5
      当前页加6
      你可以给标签价样式从而让选中的页码高亮显示
9. 针对页码小于6的情况 你需要做处理 不能再减

10. 自定义分页器的拷贝及使用

"""
当我们需要使用到非django内置的第三方功能或者组件代码的时候
我们一般情况下会创建一个名为utils文件夹 在该文件夹内对模块进行功能性划分
	utils可以在每个应用下创建 具体结合实际情况

我们到了后期封装代码的时候 不再局限于函数
还是尽量朝面向对象去封装

我们自定义的分页器是基于bootstrap样式来的 所以你需要提前导入bootstrap
	bootstrap   版本 v3
	jQuery		版本 v3
"""
# 后端
    book_queryset = models.Book.objects.all()
    current_page = request.GET.get('page',1)
    all_count = book_queryset.count()
    
# 1 传值生成对象
	page_obj = Pagination(current_page=current_page,all_count=all_count)
    
# 2 直接对总数据进行切片操作
	page_queryset = book_queryset[page_obj.start:page_obj.end]
    
# 3 将page_queryset传递到页面 替换之前的book_queryset

# 前端
    {% for book_obj in page_queryset %}
        <p>{{ book_obj.title }}</p>
        <nav aria-label="Page navigation">
    </nav>
    {% endfor %}
    {#利用自定义分页器直接显示分页器样式#}
    {{ page_obj.page_html|safe }}
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

I believe I can fly~

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

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

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

打赏作者

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

抵扣说明:

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

余额充值