0

0

Python Flask分页怎么实现_调用SQLAlchemy自带的paginate对象方法应用列表分页逻辑

P粉602998670

P粉602998670

发布时间:2026-03-13 13:46:03

|

318人浏览过

|

来源于php中文网

原创

Flask中paginate()分页必须显式传入int型page和业务指定的per_page,否则默认page=1、per_page=20易致翻页404或数据异常;应强制type=int转换、限制per_page范围,并善用.items、.pages、.has_next等内置属性简化分页逻辑。

python flask分页怎么实现_调用sqlalchemy自带的paginate对象方法应用列表分页逻辑

Flask 中用 paginate() 做分页,必须传 pageper_page

不传或传错参数,paginate() 会默认 page=1per_page=20,但你很可能没意识到——结果就是第一页数据永远对,翻页后 404 或返回空列表,还查不出原因。

常见错误现象:request.args.get('page', 1, type=int) 没加 type=int,导致传入字符串 "2"paginate() 内部类型校验失败,静默 fallback 到 page=1;或者漏传 per_page,依赖默认值,上线后发现每页突然显示 20 条而非预期的 10 条。

  • 务必从请求中显式提取 page,并强制转为 intdefault=1 是安全底线
  • per_page 不要依赖默认值,业务层应明确控制(比如固定 10,或从配置读取)
  • 如果允许前端指定 per_page,需加范围限制(如 1–100),避免 per_page=10000 直接拖垮数据库

paginate() 返回对象里哪些字段真正有用

很多人只用 .items,却忽略 .pages.has_next 这些字段,结果模板里写一堆逻辑判断当前页、总页数、是否禁用“下一页”按钮——其实都白搭,paginate() 全给你算好了。

使用场景:渲染分页导航栏、判断是否显示“上一页/下一页”、做 API 分页响应头(如 X-Total-Pages)。

立即学习Python免费学习笔记(深入)”;

歌者PPT
歌者PPT

歌者PPT,AI 写 PPT 永久免费

下载
  • .items:当前页的数据列表(已经是 Python list,不是 Query 对象)
  • .page.pages:当前页码、总页数,比手动 ceil(total / per_page) 更可靠(尤其最后一页不满时)
  • .has_prev/.has_next:布尔值,比 page > 1page 更准确(考虑了无数据时 <code>pages=0 的边界)
  • .prev_num/.next_num:直接可用的页码数字,不用再加减 1

SQLAlchemy paginate() 在不同版本行为差异大

2.0+ 版本的 paginate() 默认启用 error_out=True,页码超出范围直接抛 NotFound 异常;而 1.4 默认是 error_out=False,返回空 .items.pages=0。不留意这点,升级 SQLAlchemy 后分页接口全崩成 404。

性能影响:2.0+ 默认还会执行额外 COUNT 查询来算总页数,如果你只用“下一页”按钮(不需要总页数),可关掉:paginate(..., count=False),省一次 COUNT。

  • 显式指定 error_out=False 可统一行为,避免版本升级引发线上问题
  • 若确定不会访问非法页码(比如前端禁用跳转输入框),count=False 能明显降低小表分页延迟
  • 注意:关掉 count 后,.pages.total 就不可用了,.has_next 仍有效(靠是否查到 per_page + 1 条判断)

模板里别手写分页 URL,用 url_for() 动态构造

硬编码 /users?page=2 看似简单,但一旦路由带参数(如 /admin/users?role=admin&page=2),或 Flask 配置了 URL_PREFIX,就全乱套。更糟的是,有人把 request.args 全拼进 URL,结果把敏感参数(如 token)也透出去了。

正确做法是只保留分页相关参数,其他过滤掉。Flask 自带的 request.args.to_dict() 是起点,但得手动剔除非分页键。

  • 在视图函数里提前整理好分页上下文:pagination = query.paginate(...); pagination_args = {'page': pagination.page, 'per_page': pagination.per_page}
  • 模板中用 {{ url_for('user_list', **pagination_args) }},干净又可靠
  • 如果路由本身有变量(如 @app.route('/blog/<category_id>')</category_id>),记得把 category_id 也传进 url_for()
分页看着简单,但 page 类型、error_out 默认值、count 开关、URL 构造这四点,任一出错都会让分页逻辑在某个边界条件下悄无声息地失效。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
Python Flask框架
Python Flask框架

本专题专注于 Python 轻量级 Web 框架 Flask 的学习与实战,内容涵盖路由与视图、模板渲染、表单处理、数据库集成、用户认证以及RESTful API 开发。通过博客系统、任务管理工具与微服务接口等项目实战,帮助学员掌握 Flask 在快速构建小型到中型 Web 应用中的核心技能。

106

2025.08.25

Python Flask Web框架与API开发
Python Flask Web框架与API开发

本专题系统介绍 Python Flask Web框架的基础与进阶应用,包括Flask路由、请求与响应、模板渲染、表单处理、安全性加固、数据库集成(SQLAlchemy)、以及使用Flask构建 RESTful API 服务。通过多个实战项目,帮助学习者掌握使用 Flask 开发高效、可扩展的 Web 应用与 API。

81

2025.12.15

counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

203

2023.11.20

登录token无效
登录token无效

登录token无效解决方法:1、检查token的有效期限,如果token已经过期,需要重新获取一个新的token;2、检查token的签名,如果签名不正确,需要重新获取一个新的token;3、检查密钥的正确性,如果密钥不正确,需要重新获取一个新的token;4、使用HTTPS协议传输token,建议使用HTTPS协议进行传输 ;5、使用双因素认证,双因素认证可以提高账户的安全性。

6629

2023.09.14

登录token无效怎么办
登录token无效怎么办

登录token无效的解决办法有检查Token是否过期、检查Token是否正确、检查Token是否被篡改、检查Token是否与用户匹配、清除缓存或Cookie、检查网络连接和服务器状态、重新登录或请求新的Token、联系技术支持或开发人员等。本专题为大家提供token相关的文章、下载、课程内容,供大家免费下载体验。

843

2023.09.14

token怎么获取
token怎么获取

获取token值的方法:1、小程序调用“wx.login()”获取 临时登录凭证code,并回传到开发者服务器;2、开发者服务器以code换取,用户唯一标识openid和会话密钥“session_key”。想了解更详细的内容,可以阅读本专题下面的文章。

1092

2023.12.21

token什么意思
token什么意思

token是一种用于表示用户权限、记录交易信息、支付虚拟货币的数字货币。可以用来在特定的网络上进行交易,用来购买或出售特定的虚拟货币,也可以用来支付特定的服务费用。想了解更多token什么意思的相关内容可以访问本专题下面的文章。

2195

2024.03.01

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

760

2023.08.03

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号