一个简单的分页
# -*- coding: utf-8 -*-
class PageResult(list):
def __init__(self, total=0, page_no=1, page_size=0, edge_size=0):
self.total = total
self.page_size = page_size if page_size > 0 else 0
self.edge_size = edge_size if edge_size > 0 else 0
if page_no <= 0:
self.no = 1
elif self.max >=1 and page_no > self.max:
self.no = self.max
else:
self.no = page_no
@property
def start(self):
return (self.no - 1) * self.page_size
@property
def max(self):
if self.page_size > 0:
return (self.total + self.page_size - 1) / self.page_size
else: #不分页,显示全部条目
return 1
@property
def has_prev(self):
return self.no > 1
@property
def has_next(self):
return self.no < self.max
@property
def slider(self):
if self.edge_size > 0:
start = max(self.no - self.edge_size, 1)
stop = min(self.no + self.edge_size, self.max)
else: #不滑窗,显示全部页码
start, stop = 1, self.max
return range(start, stop + 1)
def clear(self):
del self[:]
def page_dict(self):
page = {"curr_page":self.no, "data_count":self.total, "page_count":self.max}
page["has_prev"], page["has_next"] = self.has_prev, self.has_next
page["page_range"] = self.slider
return page
class Pagination(object):
def __init__(self, query):
self.query = query
def all(self, offset=0, limit=0):
if limit == 0:
return self.query.all()
else:
return self.query.offset(offset).limit(limit).all() #SQLAlchemy orm
return self.query.all()[offset : offset + limit] #Django orm
def count(self):
return self.query.count()
def head(self):
return self.query.first()
def paginate(self, page_no=1, page_size=0, edge_size=0):
result = PageResult(self.count(), page_no, page_size, edge_size)
result.extend( self.all(result.start, result.page_size) )
return result
分享到:
相关推荐
python分页; 对字典值为number、str就行分页排序; 对元素为int、str就行分页排序
主要为大家详细介绍了python实现分页效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
结合mysql数据库查询,实现分页效果 @user.route("/user_list",methods=['POST','GET']) def user_list(): p = g.args.get("p", '') #页数 show_shouye_status = 0 #显示首页状态 if p =='': p=1 else: p=int...
#在python3上运行 from elasticsearch import Elasticsearch from urllib3.connectionpool import xrange def get_page_data(result): for hit in result['hits']['hits']: print(hit) if __name__=='__main__': ...
一个简单实用的jq分页插件,该插件将ajax抽出只进行当前为第几页的计算,请在回调内自行写入ajax请求
主要为大家详细介绍了利用flask sqlalchemy实现分页效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
基于Python实现Excel数据处理自动化生成Word文档(含索引目录 分页).zip
python 分页 pandas 数据处理 flask web 框架 jinja 模版 三、菜鸟实战 初始化 Flask 框架,设置路由 jinja 模版 渲染列表数据 分页请求数据 显示详情页数据示例 运行结果 运行截图 列表页数据示例 ...
主要介绍了Python Django 封装分页成通用的模块详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
python中的分页封装
1)分页显示列表功能包括:前后分页,指定页面跳转,设置单页显示条数 2)点击标题栏实现列表内容排序功能(这个功能花了我很长时间,在全网就没找到合适的解决方法,要不是参考了Qt开发经验,采用了变通解决办法才...
该python实现了 https://tool.lu/xiehouyu网站的获取所有列表分页数据
django+python自定义分页插件,简单易用,只需要三行代码即可展示自定义分页,支持多个展示效果
主要介绍了Python的Flask框架中实现分页功能的教程,文中的示例基于一个博客来实现,需要的朋友可以参考下
今天小编就为大家分享一篇python批量从es取数据的方法(文档数超过10000),具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
├─(141) 06 python全栈3 day58 扩展Django内置分页.avi ├─(142) 07 python全栈3 day58 自定义分页组件.avi ├─(143) 08 python全栈3 day58 DjangoForm组件初识.avi ├─(144) day58课上所有.rar (23)\\python...
一个只需要处理获取的数据的Web分页组件
主要为大家详细介绍了python flask实现分页效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下