Flask应用基础入门总结

简介: Flask应用基础入门总结

【1】使用migrate方式进行数据库连接

使用migrate方式进行数据库连接需要在终端分别运行三行代码:

#init(运行一次即可)(此db为自己设置的连接数据库的对象,可以修改)
flask db init
#(将orm模型生成迁移脚本)
flask db migrate
#(将迁移脚本映射到数据库中)
flask db upgrade 

① flask db init

执行结果为生成migrations文件夹:


② flask db migrate

#(将orm模型生成迁移脚本)
flask db migrate


如下所示这里会生成850b7054a4f6_.py,其实也就是数据模型(数据库表)迁移脚本。


这时查看数据库只有一个表alembic_verison,并且是空的。

③ flask db upgrade

执行迁移脚本,创建数据表并设置版本号。

#(将迁移脚本映射到数据库中)
flask db upgrade


【2】jinja2的使用

几个标签说明:

{% ... %}是声明标签
{{ ... }} 是打印输出表达式文本结果的标签
{# ... #} 用于注释,但是不会输出到结果文件中

① for 和 if 动态渲染select

<select name="floorId" id="floorId">
  {% for floor in floors %}
     <option value="{{ floor.id }}"
             {% if floor.id == room.floor_id %}
             selected
             {% endif %}
      >{{floor.name}}</option>
  {% endfor  %}
</select>


for循环内部使用说明:

loop.index  当前循环的迭代。(1索引)
loop.index0 当前循环的迭代。(0索引)
loop.revindex   循环结束的迭代次数(1个索引)
loop.revindex0  循环结束的迭代次数(0索引)
loop.first  如果是第一次迭代,则为true
loop.last   如果最后一次迭代为真。
loop.length 序列中的项目数。
loop.cycle  一个辅助函数,用于在序列列表之间循环。参见下面的说明。
loop.depth  指示渲染当前处于递归循环的深度。从1级开始
loop.depth0 指示渲染当前处于递归循环的深度。从0级开始

② include引入模板文件

如下所示在我们页面可以引入公共文件:

{% include 'system/common/header.html' %}
//这里为页面主体部分
{% include 'system/common/footer.html' %}

③ 表单回显

如下所示,在渲染模板的时候带回数据,那么在表单页面通过{{ }}即可回显。

@bp.get('/edit/<int:id>')
@authorize("system:repair:edit", log=True)
def edit(id):
    repair = curd.get_by_id(Repair, id)
    rooms = Room.query.all()
    return render_template('system/repair/edit.html', repair=repair, rooms=rooms)

输入框回显如下(select一样)

<input type="text" value="{{ repair.id }}" name="id"  class="layui-input">

textarea 回显如下:

<textarea type="text" name="remark" lay-verify="required"
autocomplete="off" placeholder="请输入报修说明" class="layui-textarea">
{{ repair.remark }}
</textarea>

【3】使用SQLAlchemy进行CRUD

flask默认提供模型操作,但是并没有提供ORM,所以一般开发的时候我们会采用flask-SQLAlchemy模块来实现ORM操作。


SQLAlchemy是一个关系型数据库框架,它提供了高层的 ORM 和底层的原生数据库的操作。

flask-sqlalchemy 是一个简化了 SQLAlchemy 操作的flask扩展。

① 保存对象

roomOrder = RoomOrder(user_id=userId, user_name=username, order_time=orderTime, remark=remark, )
db.session.add(roomOrder)
db.session.commit()


② 更新对象

在Flask-SQLAlchemy中,可以使用db.session对象的commit()方法来提交数据的修改。

更新单个对象

room = Room.query.get(roomOrder.room_id)
room.curr_num = room.curr_num - 1
db.session.commit()

批量更新对象

RoomOrder.query.filter_by(id=id).update({'state': 0})
db.session.commit()

③ 删除对象

删除单个对象

room = Room.query.get(roomOrder.room_id)
db.session.delete(room )
db.session.commit()

批量删除对象

res = RoomOrder.query.filter_by(name='一教').delete()
db.session.commit()

④ 查询数据

查询所有记录

# 查询所有记录
datas= RoomOrder.query.all()

条件查询

# 条件查询
data= RoomOrder.query.filter_by(name='一教').first()

排序查询

# 排序查询(升序)
datas= RoomOrder.query.order_by(RoomOrder.id.desc()).all() #asc()升序
目录
相关文章
|
7月前
|
API 数据库 数据安全/隐私保护
Flask框架在Python面试中的应用与实战
【4月更文挑战第18天】Django REST framework (DRF) 是用于构建Web API的强力工具,尤其适合Django应用。本文深入讨论DRF面试常见问题,包括视图、序列化、路由、权限控制、分页过滤排序及错误处理。同时,强调了易错点如序列化器验证、权限认证配置、API版本管理、性能优化和响应格式统一,并提供实战代码示例。了解这些知识点有助于在Python面试中展现优秀的Web服务开发能力。
109 1
|
23天前
|
监控 安全 测试技术
正确配置Flask以提高应用的安全性
正确配置Flask以提高应用的安全性
108 65
|
4月前
|
监控 测试技术 Docker
【步步惊心】Flask应用云端之旅:从本地调试到一键上线的终极秘籍!
【8月更文挑战第31天】本文详细介绍了将基于Flask框架的Web应用从本地开发环境部署到云平台的全过程。首先,通过示例代码展示了如何搭建本地环境并测试应用。接着,讲解了如何使用Docker构建生产环境镜像。最后,以Heroku为例,说明了如何将应用部署到云平台,并介绍了监控与维护的方法。通过本文的最佳实践,你可以轻松完成Flask应用的部署。
57 0
|
2月前
|
前端开发 JavaScript 数据库连接
一、Flask入门介绍
一、Flask入门介绍
47 1
|
6月前
|
关系型数据库 MySQL 数据库
如何使用Python的Flask框架来构建一个简单的Web应用
如何使用Python的Flask框架来构建一个简单的Web应用
103 0
|
4月前
|
数据可视化 前端开发 数据挖掘
【优秀python大屏】基于python flask的广州历史天气数据应用与可视化大屏
本文介绍了一个基于Python Flask框架的广州历史天气数据应用与可视化大屏系统,该系统通过数据采集、处理、分析和可视化技术,提供了丰富的气象数据展示和决策支持,帮助用户快速了解和应对气象变化。
114 3
【优秀python大屏】基于python flask的广州历史天气数据应用与可视化大屏
|
4月前
|
存储 Linux 开发工具
【Azure App Service】本地Git部署Python Flask应用上云(Azure App Service For Linux)关键错误
【Azure App Service】本地Git部署Python Flask应用上云(Azure App Service For Linux)关键错误
|
4月前
|
存储 SQL 安全
【绝密攻略】Flask应用如何抵御黑客入侵?七大安全技巧助你构建固若金汤的Web防线!
【8月更文挑战第31天】安全性是Web应用开发中的关键部分。Flask作为一款轻量级且高度可定制的框架,虽灵活但需开发者确保应用安全。本文介绍如何通过具体措施加固Flask应用,包括更新依赖项、启用CSRF保护、使用HTTPS、安全存储密码、防止SQL注入及清理用户输入等。通过示例代码展示如何在实际开发中应用这些策略,帮助提升应用安全性,为用户提供更可靠的服务。
140 0
|
4月前
|
Python Windows 内存技术
【Azure 应用服务】Azure App Service (Windows) 使用Flask框架部署Python应用,如何在代码中访问静态文件呢?如何设置文件路径?是相对路径还是绝对路径呢?
【Azure 应用服务】Azure App Service (Windows) 使用Flask框架部署Python应用,如何在代码中访问静态文件呢?如何设置文件路径?是相对路径还是绝对路径呢?
|
5月前
|
存储 数据库 开发者
Flask中的蓝图与插件应用:构建模块化Web应用的利器
【7月更文挑战第19天】Flask蓝图和插件是构建模块化、可扩展和可维护Web应用的强大工具。蓝图允许你将应用分割成多个独立的部分,提高了代码的组织性和可重用性;而插件则为Flask应用提供了丰富的功能和社区支持,简化了开发过程。通过合理地使用蓝图和插件,你可以更加高效地开发出高质量的Web应用。