# 以百度搜索分页为例亲测

# 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
• 2017年02月01日 10:45
• 388

## python有意思的分页

• u013055678
• 2017年05月04日 14:39
• 499

## 分页计算总页数算法

• lee4037
• 2014年11月18日 20:43
• 788

## Python3爬虫 处理分页

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

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

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

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

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

## MYSQL SQLServer分页查询的实现

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

## 很有用的PHP分页函数 pageft

• 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
• 2012年07月27日 16:28
• 10125

## php分页函数pageclass 有案例

• 2014年12月26日 08:54
• 9KB
• 下载

举报原因： 您举报文章：分页函数（Python） 色情 政治 抄袭 广告 招聘 骂人 其他 (最多只允许输入30个字)