Python利用flask sqlalchemy实现分页效果

作者:魂牵梦琳 时间:2023-10-05 16:36:21 

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) }}">&laquo;</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) }}">&raquo;</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,分页
0
投稿

猜你喜欢

  • 在命令行用 sort 进行排序的方法

    2023-02-23 07:07:38
  • Python函数的默认参数设计示例详解

    2021-03-23 04:31:58
  • 可以让程序告诉我详细的页面错误和数据库连接错误吗?

    2009-11-01 18:01:00
  • 几款优秀的中文字体设计

    2008-03-24 17:25:00
  • OpenCV如何去除图片中的阴影的实现

    2023-07-08 22:49:29
  • 全面了解django的缓存机制及使用方法

    2023-07-22 09:51:58
  • Python全栈之学习CSS(1)

    2022-11-07 19:05:18
  • python 调用win32pai 操作cmd的方法

    2023-11-15 12:32:09
  • 基于Opencv的图像卡通化实现代码

    2023-07-10 06:58:55
  • Django自定义过滤器定义与用法示例

    2022-07-24 13:09:00
  • Python中的列表知识点汇总

    2021-06-01 05:00:50
  • Python之字典对象的几种创建方法

    2023-04-28 13:15:57
  • 对Web开发人员有用的8个网站小结

    2022-01-16 09:39:20
  • python实现聚类算法原理

    2022-07-23 23:42:33
  • 提升Python程序性能的7个习惯

    2021-09-11 04:05:07
  • DataGrid使用心得(调用及连接数据库等等)

    2024-01-23 17:31:15
  • python实现LRU热点缓存及原理

    2022-01-08 01:26:15
  • pytorch读取图像数据转成opencv格式实例

    2021-01-31 03:12:22
  • opencv python 图像轮廓/检测轮廓/绘制轮廓的方法

    2022-08-13 06:54:59
  • XML十项特点

    2008-04-05 13:49:00
  • asp之家 网络编程 m.aspxhome.com