• 技术文章 >后端开发 >Python教程

    详解Python利用flask sqlalchemy实现分页

    零下一度零下一度2017-07-16 11:38:12原创1473
    在开发blog系统的时候,我们有一个需求,就是要显示作者已经发表的blog文章的列表,或显示作者关注者的文章列表。实现这个功能并不复杂,只需要在存储文章的数据库中过滤出指定作者的文章,然后渲染HTML显示即可。
    但是,这种方法在文章不多的情况下或许是可行的,当文章的数量变多的时候,就无法在一页中显示完所有的文章了。这时就需要将文章列表进行分页显示,每一页只显示指定数量的文章。
    这个功能应该如何实现呢?我们能想到的一个直观的方法就是将从数据库中过滤得到的文章列表进行分组,每次只显示一组文章。然后根据用户的需要来显示指定组的文章列表。

    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) %}
      <p 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>
      </p>
    {% endmacro %}


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

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

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

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

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

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

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

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

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

    以上就是详解Python利用flask sqlalchemy实现分页的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:sqlalchemy Python flask
    上一篇:Python基础汇总 下一篇:python记录程序运行时间的方法介绍
    VIP课程(WEB全栈开发)

    相关文章推荐

    • 【活动】充值PHP中文网VIP即送云服务器• 手把手教你在Python使用plot()函数画图• 详细解析python正则表达式re模块• 一文搞定Python中pip的安装与使用• 一文详解python生成器• Python实战解析selenium的基本元素与键盘鼠标模拟事件
    1/1

    PHP中文网