首页 > 编程 > Python > 正文

Python利用flask sqlalchemy实现分页效果

2020-02-16 01:53:10
字体:
来源:转载
供稿:网友

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

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

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

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

from datetime import datetimeclass 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_templatefrom flask.views import MethodViewclass 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 %}            
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表