python框架flask知识总结
作者:胖虎是只mao 发布时间:2023-07-27 20:24:53
一、Flask蓝图目录
我们之前写的Flask项目都是自己组织的目录结构,其实Flask官方有其推荐的目录结构,以下就是一个符合官方推荐的Flask小型应用的项目结构目录示例,如下:
如图,这就是我们建立好的一个目录结构,一层一层的看一下,首先是app目录,它就是我们的主应用程序目录了,其中有一个__init__.py文件,里面的内容如下:
app/init.py
from flask import Flask
from .views.acc import acc_bp
from .views.user import user_bp
def create_app():
my_app = Flask(__name__)
my_app.register_blueprint(acc_bp)
my_app.register_blueprint(user_bp)
return my_app
app/__init__.py
__init__.py
就是构建app的一个函数,并且将views中的蓝图注册进去了。
接下来看static目录,这个目录从字面意思就可以理解了,是我们的static静态文件存放目录。
然后就是templates目录,即模板存放目录。
views目录,主角终于登场了,这里存放的就是视图函数文件,也就是我们Blueprint
,每一个文件就是一个Blueprint,如下:views/acc.py
from flask import Blueprint
acc_bp = Blueprint('acc', __name__)
@acc_bp.route("/acc")
def accfunc():
return "my_app.acc"
views/acc.py
views/user.py
from flask import Blueprint
user_bp = Blueprint('user', __name__)
@user_bp.route("/login")
def user_login():
return "my_app.user"
views/user.py
接下来就是关键性的一个文件manager.py,项目的启动文件,内容如下:
manager.py
from app import create_app
my_app = create_app()
if __name__ == '__main__':
my_app.run()
manager.py
二、Flask-SQLAlchemy
1、安装
pip install Flask-SQLAlchemy
2、接下来基于上面的Flask项目,我们要加入Flask-SQLAlchemy让项目变得生动起来
2.1 加入Flask-SQLAlchemy第三方组件
app/__init__.py
from flask import Flask
from flask_sqlalchemy import SQLAlchemy # 导入Flask-SQLAlchemy中的SQLAlchemy
db = SQLAlchemy() # 实例化SQLAlchemy
# 注意:实例化SQLAlchemy的代码必须要在引入蓝图之前
# 引入蓝图
from .views.acc import acc_bp
from .views.user import user_bp
def create_app():
my_app = Flask(__name__)
# 初始化app配置,专门针对SQLAlchemy 进行配置
my_app.config["SQLALCHEMY_DATABASE_URI"] = "mysql+pymysql://root:@127.0.0.1:3306/wll?charset=utf8"
my_app.config["SQLALCHEMY_POOL_SIZE"] = 5 # SQLAlchemy的连接池大小
my_app.config["SQLALCHEMY_POOL_TIMEOUT"] = 15 # SQLAlchemy的连接超时时间
my_app.config["SQLALCHEMY_TRACK_MODIFICATIONS"] = False
db.init_app(my_app) # 初始化SQLAlchemy , 本质就是将以上的配置读取出来
my_app.register_blueprint(acc_bp)
my_app.register_blueprint(user_bp)
return my_app
app/__init__.py
2.2 在app目录下建立models.py(ORM模型文件)
app/models.py
from app import db
# from sqlalchemy.ext.declarative import declarative_base
# Base = declarative_base()
# 之前我们在创建数据表的时候都要做这样一件事,然而Flask-SQLAlchemy已经为我们把 Base 封装好了,即db.Model
# 建立users数据表
class Users(db.Model):
__tablename__ = 'users'
# __table_args__ = {"useexisting": True}
# Flask-SQLAlchemy 也为我们封装好了Column,Integer,String等
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String(32))
password = db.Column(db.String(32))
if __name__ == '__main__':
from app import create_app
my_app = create_app()
# 这里你要回顾一下Flask应用上下文管理了
# 离线脚本:
with my_app.app_context():
db.drop_all() # 删除所有表
db.create_all() # 创建表
app/models.py
2.3 登录视图函数
还记不记得我们在sqlalchemy中手动打开会话 db_session
from sqlalchemy.orm import sessionmaker
Session = sessionmaker(engine)
db_session = Session()
现在不用了,因为 Flask-SQLAlchemy 也已经为我们做好会话打开的工作
from flask import Blueprint, request, render_template
user_bp = Blueprint('user', __name__)
from app.models import Users
from app import db
@user_bp.route("/login", methods=['GET', 'POST'])
def user_login():
if request.method == 'POST':
username = request.form.get('username')
password = request.form.get('password')
# 还记不记得我们在sqlalchemy中手动打开会话 db_session
# from sqlalchemy.orm import sessionmaker
# Session = sessionmaker(engine)
# db_session = Session()
# 现在不用了,因为 Flask-SQLAlchemy 也已经为我们做好会话打开的工作
db.session.add(Users(name=username,password=password))
db.session.commit()
# 查询
user_obj = Users.query.filter(Users.name == username and Users.password == password).first()
if user_obj:
return f"{user_obj.name}登录成功"
return render_template("login.html")
views/user.py
2.4 登陆页面
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
</head>
<body>
<form method="post" action="">
<input type="text" name="username">
<input type="password" name="password">
<input type="submit">
</form>
</body>
</html>
templates/login.html
三、Flask-Script
1、安装
pip install Flask-Script
2、接下来再基于上面的项目,加入Flask-Script,使我们可以用命令启动项目
其实本部分就是为下面的Flask-Migrate做铺垫,Flask-Script 顾名思义就是 Flask 的脚本。你是否还记得Django的启动命令呢?没错,就是 python manager.py runserver,其实Flask也可以做到,基于 Flask-Script 就可以了。
3.1 将Flask-Script加入到Flask项目中
from flask_script import Manager # 导入Flask-Script中的Manager
from app import create_app
my_app = create_app()
manager = Manager(my_app) # 让app支持manager
if __name__ == '__main__':
# my_app.run()
manager.run() # 替换原来的 my_app.run() 就可以了
manager.py
3.2 使用命令启动Flask项目
python manager.py runserver
3.3 启动Flask项目,并更改配置参数(监听的IP地址和端口号)
python manager.py runserver -h 0.0.0.0 -p 9527
3.4 高级操作 - 自定制脚本命令
方式一:@manager.command
from flask_script import Manager # 导入Flask-Script中的Manager
from app import create_app
my_app = create_app()
manager = Manager(my_app) # 让app支持manager
@manager.command
def runflask(arg):
# my_app.run() # 释放此句项目humg住
print(arg)
if __name__ == '__main__':
# my_app.run()
manager.run() # 替换原来的 my_app.run() 就可以了
manager.py
执行命令:
python manager.py runflask 22
结果如下图:
执行命令:
python manager.py talk -n 你 -s 厉害
python manager.py talk --name 我 --say 厉害
四、Flask-Migrate
1、安装
pip install Flask-Migrate
2、继续基于上面的项目,使Flask项目支持makemigration和migrate
4.1 将 Flask-Migrate (注意:Flask-Migrate要依赖Flask-Script组件)加入到项目中
from flask_script import Manager # 导入Flask-Script中的Manager
# 导入 Flask-Migrate 中的 Migrate 和 MigrateCommand
# 这两个东西说白了就是想在 Flask-Script 中添加几个命令和指令而已
from flask_migrate import Migrate, MigrateCommand
from app import create_app
my_app = create_app()
manager = Manager(my_app) # 让app支持manager
from app import db
Migrate(my_app, db) # 既然是数据库迁移,那么就得告诉他数据库在哪里,并且告诉他要支持哪个app
# 接下来再告诉manager 有新的指令了,这个新指令在MigrateCommand 中存着呢
manager.add_command("database", MigrateCommand) # 当你的命令中出现 database 指令,则去MigrateCommand中寻找对应关系
"""
数据库迁移指令:
python manager.py database init
python manager.py database migrate # 相当于Django中的 makemigration
python manager.py database upgrade # 相当于Django中的 migrate
"""
@manager.command
def runflask(arg):
# my_app.run() # 释放此句项目humg住
print(arg)
@manager.option("-n", "--name", dest="name")
@manager.option("-s", "--say", dest="say")
def talk(name, say):
print(f"{name}可真{say}")
if __name__ == '__main__':
# my_app.run()
manager.run() # 替换原来的 my_app.run() 就可以了
manager.py
4.2 执行数据库初始化指令
python manager.py database init
此时你会发现你的项目目录中出现了一个migrations目录,如下图:
4.3 执行数据库迁移指令
python manager.py database migrate # 相当于Django中的 makemigration
python manager.py database upgrade # 相当于Django中的 migrate
结果如下图:
此时你会发现数据库中出现了一个users表。
来源:https://blog.csdn.net/xili2532/article/details/117096086


猜你喜欢
- 前言写这次博客其实事出有因,前几天呢,一个非常优秀的学姐在QQ空间里晒了自己的CSDN博客的总阅读量,达到了7万+,很厉害了,而且确实她的博
- 常见的几种分页方式:1.扶梯方式扶梯方式在导航上通常只提供上一页/下一页这两种模式,部分产品甚至不提供上一页功能,只提供一种“更多/more
- 这回我们看看如何实现判断两个对像的内容是否相等。这里有一个克隆结果原则是针对Java语言的,当然JavaScript也可以胜任。克隆满足的条
- 概述OpenCV 是一个跨平台的计算机视觉库, 支持多语言, 功能强大. 今天小白就带大家一起携手走进 OpenCV 的世界. 高
- 1. 问题使用PyCharm 创建完Django 项目 想登录admin 页面 却不知道用户名和密码。 用的默认sqlit2.解决办法2.1
- Python命令行假设你已经安装好了Python, 那么在Linux命令行输入:$python将直接进入python。然后在命令行提示符&g
- 打印100-999之间的回文数(即百位和个位的数字相等),并每10个打印一行i = 100x = 0 # 使用计数器,每10个换行打印whi
- Python中的array模块是一个预定义的数组,因此其在内存中占用的空间比标准列表小得多,同时也可以执行快速的元素级别操作,例如添加、删除
- 我们来编写一个,引用时用:<!--#include Virtual="page.inc"-->语句即可:pa
- MySQL中union和order by是可以一起使用的,但是在使用中需要注意一些小问题,下面通过例子来说明。首先看下面的t1表。1、如果直
- 以前从来没有写过特别多的代码,这次在阅读论文的时候跑别人的代码的时候出现了很多import的问题,这里我想跟大家分享一下,我在Ubuntu系
- 本文实例讲述了Python中的is和id用法。分享给大家供大家参考。具体分析如下:(ob1 is ob2) 等价于 (id(ob1) ==
- 首先编写py程序:printtest.pydef test(): print('print test')将以上.
- 比如我们要读取一个桌面路径下的文件 设计 一个函数 怎么写才能正确?注意以下两点就可以了1、对于一个路径 例如C:\Users\xiaomi
- DataSet是tensorflow 1.3版本推出的一个high-level的api,在1.3版本还只是处于测试阶段,1.4版本已经正式推
- 支持向量机常用于数据分类,也可以用于数据的回归预测1、Question?我们经常会遇到这样的问题,给你一些属于两个类别的数据(如子图1),需
- 如果你完全不懂,那么期望1-2周看完一遍拉倒....不用看的太仔细,后面再看到不懂的时候回头去看这些东西好了1. 前言和准备工作 这里不会介
- 前言:随着互联网技术的不断发展, MySQL 相关生态也越来越完善,越来越多的工具涌现出来。一些公司或个人纷纷开源出一些不错的工具,本篇文章
- 一、什么是七段数码显示器 七段LCD数码显示器
- 最近越来越多在博客上写些UX相关的内容作为分享,就涉及到跟普通博文不一样的文章建构问题。文章内容固然很重要,但排版、组织也是提高可读性和用户