分页函数(Python)

原创 2016年06月01日 09:04:06

以百度搜索分页为例亲测

# coding=utf-8
def get_page(m, n):
    cur_page = n
    pages = []

    if cur_page <= 6:    # 百度分页为例
        limit_start = 1       # 起始页
    else:
        limit_start = cur_page-5

    if m >= cur_page+4:

        if cur_page < 6:
            limit_end = m-limit_start
        else:
            limit_end = cur_page + 4

    else:
        limit_end = m
        if cur_page >= 10:
            limit_start = limit_end-9

    for i in xrange(limit_start, limit_end+1):    # 这才是分页的关键

        if cur_page == i:
            pages.append(cur_page)
        else:
            pages.append(i)

    return pages

进一步精简代码:

# coding=utf-8
PER_PRE_NUM = 6
PER_NUMBER_MAX = 10


def get_page(m, n):
    cur_page = n
    limit_start = 1 if cur_page <= PER_PRE_NUM else cur_page - (PER_PRE_NUM-1)
    if m >= cur_page+(PER_PRE_NUM-2):
        limit_end = m - limit_start if cur_page < PER_PRE_NUM else cur_page + (PER_PRE_NUM-2)
    else:
        limit_end = m
        if cur_page >= PER_NUMBER_MAX:
            limit_start = limit_end-(PER_NUMBER_MAX-1)
    return [i for i in xrange(limit_start, limit_end+1)]

测试:

assert get_page(7, 5) == [1, 2, 3, 4, 5, 6, 7]
assert get_page(12, 6) == [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
assert get_page(12, 7) == [2, 3, 4, 5, 6, 7, 8, 9, 10, 11]
assert get_page(11, 3) == [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
assert get_page(11, 6) == [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
assert get_page(11, 7) == [2, 3, 4, 5, 6, 7, 8, 9, 10, 11]
assert get_page(100, 99) == [91, 92, 93, 94, 95, 96, 97, 98, 99, 100]
print(get_page(11, 1))
print(get_page(76, 25))
print(get_page(100, 50))

学习是一个不断纠错的过程,回头看看,会有很多的考虑不周到,再次自己提出来,避免有需要的朋友走弯路

# coding=utf-8

PER_PRE_NUM = 6
PER_NUMBER_MAX = 10

# 百度分页为例
def get_page(m, n):
    cur_page = n  # 当前页
    if m > PER_NUMBER_MAX:
        limit_start = 1 if cur_page <= PER_PRE_NUM else cur_page - (PER_PRE_NUM - 1)

        if m >= cur_page+(PER_PRE_NUM-2):
            if n >= PER_PRE_NUM:
                limit_end = m - limit_start if cur_page < PER_PRE_NUM else cur_page + (PER_PRE_NUM - 2)
            else:
                limit_end = PER_NUMBER_MAX
        else:
            limit_end = m
            if cur_page >= PER_NUMBER_MAX or ((limit_end - limit_start) < PER_NUMBER_MAX):
                limit_start = limit_end - (PER_NUMBER_MAX - 1)

    else:
        limit_start, limit_end = 1, m

    return [i for i in xrange(limit_start, limit_end + 1)]


print(get_page(7, 5))
assert get_page(7, 5) == [1, 2, 3, 4, 5, 6, 7]
assert get_page(12, 6) == [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
assert get_page(12, 7) == [2, 3, 4, 5, 6, 7, 8, 9, 10, 11]
assert get_page(11, 3) == [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
assert get_page(11, 6) == [1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
assert get_page(11, 7) == [2, 3, 4, 5, 6, 7, 8, 9, 10, 11]
assert get_page(100, 99) == [91, 92, 93, 94, 95, 96, 97, 98, 99, 100]
print(get_page(11, 1))
print(get_page(76, 25))
print(get_page(18, 2))
print(get_page(11, 8))
print(get_page(11, 7))



版权声明:本文为博主原创文章,未经博主允许不得转载。

python 带分页

#coding=utf-8 import re import requests import os import MySQLdb def findimg(url): header = { ...
  • u013027894
  • u013027894
  • 2017年02月01日 10:45
  • 388

python有意思的分页

最近搞mongodb,同时查两张表数据,我把数据并在一个list中,但是要分页,我知道的分页就是skip,limit,发现放哪张表里也不合适,只能对一个list进行分页处理 # -*- coding:...
  • u013055678
  • u013055678
  • 2017年05月04日 14:39
  • 499

分页计算总页数算法

转自:http://blog.csdn.net/vange/article/details/5644931
  • lee4037
  • lee4037
  • 2014年11月18日 20:43
  • 788

Python3爬虫 处理分页

import logging import random import threading import urllib.parse import urllib.parse import urllib....
  • u013491262
  • u013491262
  • 2017年07月26日 17:13
  • 386

python爬虫——爬取用js实现翻页的网站

——————————————-背景介绍——————————————— 首先,这次想爬取的网站地址为:http://www.zhuhai.gov.cn/hd/zxts_44606/tsfk/查看网站的...
  • linzch3
  • linzch3
  • 2017年06月06日 16:31
  • 3850

dataTable实现服务器端分页(python)

dataTable有两种分页方式: 一种是页面分页(把数据一次性加载到页面,然后再分页),另一种是服务器端分页. 由于后台数据较多,采用页面分页耗时太长,页面分页还有一个弊端,就是除了第一页,后面的页...
  • python_tty
  • python_tty
  • 2016年07月13日 14:09
  • 2656

MYSQL SQLServer分页查询的实现

SQLServer 的数据分页: 假设现在有这样的一张表: CREATE TABLE test (  id int primary key not null identity,  names varc...
  • QQQQQQ654
  • QQQQQQ654
  • 2016年09月12日 07:58
  • 374

很有用的PHP分页函数 pageft

  • lewis_tdl
  • lewis_tdl
  • 2009年04月12日 11:26
  • 2231

分页 Page 类

package ssh.core.orm; import java.util.ArrayList; import java.util.List; import org.apache.commons...
  • maxuyang1987
  • maxuyang1987
  • 2012年07月27日 16:28
  • 10125

php分页函数pageclass 有案例

  • 2014年12月26日 08:54
  • 9KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:分页函数(Python)
举报原因:
原因补充:

(最多只允许输入30个字)