Flask学习之改编成你认识的MVC结构
温馨提示:这篇文章已超过385天没有更新,请注意相关的内容是否还可用!
启动剥离
from app.Kernel import Kernel
### 启动
if __name__ == '__main__':
Kernel.bootstrap()
启动文件
### 初始化项目
app = Flask(__name__, template_folder=env.TEMPLATE, static_folder=env.STATIC)
app.debug = env.DEBUG
@classmethod
def bootstrap(cls):
return cls.app.run( host=env.HOST, port=env.PORT )
数据库剥离
#### 数据库实例化
try:
Database.init( app )
except Exception as e:
raise AttributeError( f'数据库链接异常:{e}' )
模型注入
"""
初始化数据库驱动
"""
@classmethod
def init(cls, app ):
try:
if 'mysql' == cls.config.default:
cls.driver = Mysql( cls.config.drivers[cls.config.default] )
except Exception as e:
raise Exception( e )
app.config.from_object( cls.driver )
Base.inject_app( app )
return True
模型基类
from flask_sqlalchemy import SQLAlchemy
class Base:
db = SQLAlchemy()
def __init__(self):
pass
@classmethod
def inject_app(cls, app):
cls.db.init_app( app )
return cls.db
模型改写
#### 引入基类
from Flask.app.Models.Base import Base
###### Base.db.Model Flask模型基类
class Users( Base.db.Model ):
"""
站点数据表映射
"""
### 改写db指向
db = Base.db
### 映射表名称
__tablename__ = 'users'
id = db.Column(db.Integer, primary_key=True, autoincrement=True )
created_at = db.Column(db.DateTime, nullable=False )
updated_at = db.Column(db.DateTime, nullable=False )
name = db.Column(db.String(32), index = True, nullable=False )
email = db.Column(db.String(64), unique=True, index = True, nullable=False )
password = db.Column(db.String(64), unique=True, index = True, nullable=False )
email_verified_at = db.Column( db.Time )
email_verified_at = db.Column(db.String(100))
# 关联关系
"""
lazy: 指定sqlalchemy数据库什么时候加载数据
select: 就是访问到属性的时候,就会全部加载该属性的数据
joined: 对关联的两个表使用联接
subquery: 与joined类似,但使用子子查询
dynamic: 不加载记录,但提供加载记录的查询,也就是生成query对象
"""
sites = db.relationship( "Sites", backref='user', uselist=True, lazy='dynamic' )
def __repr__(self):
return '' % self.name
如上述代码中关联关系设置关键词: Lazy dynamic
(图片来源网络,侵删)
那么这里设置的是动态加载,那么我们获取到数据之后管理查询时就需要重新去查询。
#关联取数据
user = Users.query.get(1)
sites = user.sites.all()
for item in sites :
print( f"站点编号:{item.id}, 站点名称:{item.name}, 创建人:{item.user.name}, 站点邮件:{item.email}, 站点电话:{item.phone}, 创建时间:{item.created_at}")
模型操作
查找
### 查找
#### get 主键查找
site = Sites.query.get(1)
print( f"站点编号:{site.id}, 站点名称:{site.name}, 创建人:{site.user.name}, 站点邮件:{site.email}, 站点电话:{site.phone}, 创建时间:{site.created_at}" )
#### filter_by
sites = Sites.query.filter_by( name='www.google.com' )
print(f"站点编号:{site.id}, 站点名称:{site.name}, 站点邮件:{site.email}, 站点电话:{site.phone}, 创建时间:{site.created_at}")
for item in sites:
print(f"站点编号:{item.id}, 站点名称:{item.name}, 站点邮件:{item.email}, 站点电话:{item.phone}, 创建时间:{item.created_at}")
修改
### 修改 site.email='email@google.com' db.session.commit()
删除
# ### 删除 site = Sites.query.get(7) db.session.delete( site ) db.session.commit()
路由剥离
from flask import Blueprint
### 初始化 Blueprint
bp = Blueprint( 'dashbord', __name__, url_prefix='/' )
"""
System Index
后端数据传递 - 多参数传递视图 , 分割
"""
@bp.route( '/index', methods=['GET'] )
@bp.route( '/', methods=['GET'] )
def dashbord():
data = {
'uid': 1,
'uname': "Carey"
}
return render_template( 'index.html', user = data )
### 引入路由模块 from Flask.app.Controller.dashbord import bp #### 模块注入 app.register_blueprint(bp)
Gitee链接地址 : Flask 更改为MVC: Python Flask框架改为MVC
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!
