Python利用flask sqlalchemy实现分页效果


Posted in Python onAugust 02, 2020

Flask-sqlalchemy是关于flask一个针对数据库管理的。文中我们采用一个关于员工显示例子。

首先,我们创建SQLALCHEMY对像db。

from flask import Flask, render_template,request
from flask_sqlalchemy import SQLAlchemy

app = Flask(__name__,static_url_path='')
app.debug = True
app.secret_key = "faefasdfaf"
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite:///./db/personal.db' # app的配置,指定数据库路径
app.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = True
app.config['SQLALCHEMY_ECHO'] = True 

db = SQLAlchemy(app)

然后我们利用db创建员工表:

from datetime import datetime

class Employee(db.Model):
 '''员工'''
 __tablename__ = 'employee'

 id = db.Column(db.Integer, primary_key=True)
 name = db.Column(db.String(50))
 gender = db.Column(db.String)
 job = db.Column(db.String)
 birthday = db.Column(db.DateTime)
 idcard = db.Column(db.String)
 address = db.Column(db.String)
 salary = db.Column(db.String)
 release_time = db.Column(db.DateTime)

 def __init__(self, name, gender, job, birthday, idcard, address, salary, release_time=None):
  self.name = name
  self.gender = gender
  self.job = job
  self.birthday = birthday
  self.idcard = idcard
  self.address = address
  self.salary = salary
  self.release_time = release_time if release_time else datetime.now()

 def __repr__(self):
  return '<员工{},{},{},{}>'.format(self.id, self.name, self.salary, self.address)

表创建好之后,我们可以从表中查询数据了。

from flask import render_template
from flask.views import MethodView
class EmployeeListView(MethodView): # 获取员工信息
 def get(self,page=1):
  employees = Employee.query.paginate(page,per_page=10)
  return render_template('employeelist.html', employees=employees)

以上我们通过查询,查询出员工信息,然后传给前台一个模板。(以上我们采用了flask的蓝图进行了分模块,假设我们把上面这个定义为视图函数为:employee.list)

注:paginate是分页的方法,第一个参数是页码,第二个是每页显示多少条。但是这样得到的结果不是一列表,需要在传到前台的值加一个 .items,下面举例说明。(利用jinja2模板)

 {% for item in employees.items %}

如上所示,在利用Jinja2去取值时,需要在后台传过来的值后面,加上.items。

继续上面的分页,这里我们要再次利用jinja2模板来定义一个方法,以实现分页的功能,这个页面名字就叫:helper.html。

{% macro render_page_data(page_data,page_function) %}
 <div class="text-center">
  <ul class="page_data">
   <li><a href="{{ url_for(page_function,page = 1) }}">首页</a></li>
   {% if page_data.has_prev %}
    <li><a href="{{ url_for(page_function,page = page_data.prev_num) }}">«</a></li>
   {% endif %}
   {% for page in page_data.iter_pages() %}
    {% if page %}
     {% if page !=page_data.page %}
      <li><a href="{{ url_for(page_function,page = page) }}">{{ page }}</a></li>
     {% else %}
      <li class="active"><a href="#">{{ page }}</a></li>
     {% endif %}
    {% endif %}
   {% endfor %}
   {% if page_data.has_next %}
    <li><a href="{{ url_for(page_function,page = page_data.next_num) }}">»</a></li>
   {% endif %}
   <li><a href="{{ url_for(page_function,page = page_data.pages) }}">末页</a></li>
  </ul>
 </div>
{% endmacro %}

以上是我们利用jinja2的语法定义了一个分布的方法,这个方法,我们传了二个参数,第一个是后台传过来通过db分页查询出来的数据。第二个是我们查询的数据的方法。

这里需要特别说明一下,分页的数据有几个重要的方法:

  • has_next:如果在目前页后至少还有一页的话,返回 True
  • has_prev:如果在目前页之前至少还有一页的话,返回 True
  • next_num:下一页的页面数
  • prev_num:前一页的页面数

通过上面的工作之后,最后就只差一步了,我们需要在我们的模板页通过Jinja2导入我们刚刚定义的方法,也就是在上面我们的employeelist.html中导入。

{% import 'helper.html' as helper %}

导入之后,我们就可以在我们需要的地方调用就可以了。

{{ helper.render_pagination(employees,'employee.list') }}

上面就是我们调用我们之前定义的方法。第一个参数,我们从后台传过来的值,第二个就是后台的那个视图函数。

进行了以上操作后,我们就大功告成了,下面看一下,我们实现了的效果图。

Python利用flask sqlalchemy实现分页效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Python 相关文章推荐
深入理解NumPy简明教程---数组3(组合)
Dec 17 Python
TensorFlow实现MLP多层感知机模型
Mar 09 Python
python计算两个数的百分比方法
Jun 29 Python
Python爬虫的两套解析方法和四种爬虫实现过程
Jul 20 Python
Python简单过滤字母和数字的方法小结
Jan 09 Python
python如何制作缩略图
Apr 30 Python
python3+PyQt5 自定义窗口部件--使用窗口部件样式表的方法
Jun 26 Python
python zip()函数使用方法解析
Oct 31 Python
使用Django xadmin 实现修改时间选择器为不可输入状态
Mar 30 Python
用opencv给图片换背景色的示例代码
Jul 08 Python
pytorch加载预训练模型与自己模型不匹配的解决方案
May 13 Python
python随机打印成绩排名表
Jun 23 Python
Python实现发送QQ邮件的封装
Jul 14 #Python
python记录程序运行时间的三种方法
Jul 14 #Python
python运行其他程序的实现方法
Jul 14 #Python
Python利用递归和walk()遍历目录文件的方法示例
Jul 14 #Python
Python学习教程之常用的内置函数大全
Jul 14 #Python
python与C互相调用的方法详解
Jul 14 #Python
Python django实现简单的邮件系统发送邮件功能
Jul 14 #Python
You might like
鸡肋的PHP单例模式应用详解
2013/06/03 PHP
PHP读取文件内容的五种方式
2015/12/28 PHP
Yii2配置Nginx伪静态的方法
2017/05/05 PHP
PHP getNamespaces()函数讲解
2019/02/03 PHP
Laravel框架Request、Response及Session操作示例
2019/05/06 PHP
jQuery实现公告新闻自动滚屏效果实例代码
2016/07/14 Javascript
再谈javascript常见错误及解决方法
2016/09/16 Javascript
jQuery实现6位数字密码输入框
2016/12/29 Javascript
js 获取元素的具体样式信息getcss(实例讲解)
2017/07/05 Javascript
微信小程序的mpvue框架快速上手指南
2019/05/15 Javascript
VUE子组件向父组件传值详解(含传多值及添加额外参数场景)
2020/09/01 Javascript
Python 的描述符 descriptor详解
2016/02/27 Python
Django Rest framework三种分页方式详解
2019/07/26 Python
tensorflow mnist 数据加载实现并画图效果
2020/02/05 Python
Python闭包及装饰器运行原理解析
2020/06/17 Python
html5菜单折纸效果
2014/04/22 HTML / CSS
HTML5 Canvas中使用用路径描画圆弧
2015/01/01 HTML / CSS
英国文胸专家:AmpleBosom.com
2018/02/06 全球购物
Crucial英睿达法国官网:内存条及SSD固态硬盘升级
2018/07/13 全球购物
俄罗斯园林植物网上商店:Garshinka
2020/07/16 全球购物
blueseventy官网:铁人三项和比赛泳衣
2021/02/06 全球购物
abstract是什么意思
2012/02/12 面试题
信号量和自旋锁的区别?如何选择使用?
2015/09/08 面试题
财务会计实习报告体会
2013/12/20 职场文书
驾驶员培训方案
2014/05/01 职场文书
公司贷款承诺书
2014/05/30 职场文书
团队队名口号大全
2014/06/06 职场文书
学习优秀党务工作者先进事迹材料思想报告
2014/09/17 职场文书
领导班子四风问题对照检查材料
2014/09/27 职场文书
远程教育培训心得体会
2016/01/09 职场文书
小学三年级作文之写景
2019/11/05 职场文书
再见,2019我们不负使命;你好,2020我们砥砺前行
2020/01/03 职场文书
python文件名批量重命名脚本实例代码
2021/04/22 Python
python基于tkinter制作m3u8视频下载工具
2021/04/24 Python
详细了解MVC+proxy
2021/07/09 Java/Android
Apache自带的ab压力测试工具的实现
2022/07/23 Servers