前言:
Flask简介:Flask是一个使用 Python 编写的轻量级 Web 应用框架,基于 WerkzeugWSGI工具箱和 Jinja2模板引擎。
想要学习flask,又非常迷茫,不知如何下手,终于写下第一个项目,分享给大家,希望能对刚刚入门的你有所帮助。
flask+flask_bootstrap+flask_wtf+mysql
一、项目目录
static目录:存放静态文件
templates目录:用来存放响应的html文件
forms.py:存放表单定义
model.py:定义数据模型
app.py:视图函数
data:image/s3,"s3://crabby-images/49d7c/49d7caeeed18839e586a59ac52d308988b4350a0" alt=""
二、数据库部分
本次使用的数据库是MySQL,需要安装flask-sqlalchemy来管理数据库
>>>pip install flask-sqlalchemy
1、使用URL制定数据库
mysql://username:password@hostname/database
data:image/s3,"s3://crabby-images/d09ab/d09ab5f4a8b62c4eb5e3b8758a636808ece005ae" alt=""
2、执行sql语句
进入mysql命令行:(sql文件的目录根据自己的真实路径来修改)
mysql> . /Users/workpace/flask-1/sql_flask.sql
data:image/s3,"s3://crabby-images/b675b/b675b12a0273107c839437cff29e9f19aef75e44" alt=""
3、定义数据模型
data:image/s3,"s3://crabby-images/bc378/bc378f25c84ff411806f52a1a031782a0b9cb1e1" alt=""
4、插入行db.session.add()
data:image/s3,"s3://crabby-images/3b5f6/3b5f6ffcdd0f94dbc9464ea96ae8f226e8962690" alt=""
5、删除行db.session.deleted()
data:image/s3,"s3://crabby-images/08e38/08e3866ffb32ea515b2e4e073e129fb4c518b81e" alt=""
6、查询行Role.query
查询全部:Role.query.all()
条件查询(使用过滤器):User.query.filter_by(role=user_role).all()
data:image/s3,"s3://crabby-images/055a4/055a4d60d1da3f9a745783c1ada2129409639cd1" alt=""
三、表单定义
需要安装flask_wtf,WTForms
>>>pip install flask_wtf
>>>pip install WTForms
data:image/s3,"s3://crabby-images/64e79/64e797ff3ae438538bb5a5ff762266b8569f8392" alt=""
四、视图函数
使用程序实例提供的app.route修饰器,把修饰的函数注册为路由,添加的methods参数告诉Flask在URL映射中把这个视图函数注册为GET和POST请求的处理程序。
最后一行调用render_template()函数渲染模板。
需要安装flask_bootstrap
>>>pip install flask_bootstrap
data:image/s3,"s3://crabby-images/886ce/886cec6b0a7d8e83839a53f485ce597ef5fd8174" alt=""
五、运行页面
data:image/s3,"s3://crabby-images/d2503/d2503f238f608339ff3fd445074c9b88746b0f83" alt=""
data:image/s3,"s3://crabby-images/9c09a/9c09a42be261becd1e8ed75398d37b4c86325df0" alt=""
data:image/s3,"s3://crabby-images/7ed2f/7ed2f545d50b97327cbcd67d2876f30fa4a726b2" alt=""
6、开源代码
链接: https://github.com/wangxiaoxi3/Flask_test_1
以上,希望能对你有所帮助~~