如何在烧瓶中引用多个模型?

joh*_*nny 2 python model sqlalchemy flask flask-sqlalchemy

如何在 Flask 应用程序中处理和引用多个模型?

是否有任何原因我不能拥有多个模型类、.py文件?而不是一个 big models.py,有没有办法在烧瓶中有以下内容:

示例模型:

students.py
teachers.py
classes.py
schedules.py
...
Run Code Online (Sandbox Code Playgroud)

?

小智 6

这是一个我想像 Django 一样构建的 Flask 应用程序:

/blog_project
    config.py
    wsgi.py
    .gitignore
    /blog_app
        __init__.py # where factory application resides 
        /users
            /static
            /templates
            __init__.py
            models.py
            routes.py
            views.py
       /posts
            /static
            /templates
            __init__.py
            models.py
            routes.py
            views.py
Run Code Online (Sandbox Code Playgroud)

我试图以类似于Django项目的方式构建我的 Flask 应用程序,因为我的应用程序变得过于笨拙且难以维护。我有一个工厂应用程序函数,它创建 Flask 应用程序对象,该对象已注册到 Flask Blueprints

# users/routes.py

# import 
from Flask import Blueprint
from users.views import get_users

# Create Flask Blueprint object
user_pb = Blueprint(
    'user_pb',
    __name__,
    template_folder='templates',
    static_folder='strains/static'
)

@user_bp.route('/users', methods=['GET'])
def users():
    return get_users()
Run Code Online (Sandbox Code Playgroud)
# posts/routes.py

# import 
from Flask import Blueprint
from users.posts import get_posts

# Create Flask Blueprint object
post_pb = Blueprint(
    'post_pb',
    __name__,
    template_folder='templates',
    static_folder='strains/static'
)

@user_bp.route('/posts', methods=['GET'])
def posts():
    return get_posts()


Run Code Online (Sandbox Code Playgroud)
# posts/models.py

# import sql-alchemy db instance created with factory application
from blog_app import db


class Post(db.Model):
    """
    A simple model with a string based column 'content'.
    """
    id = db.Column(db.Integer, primary_key=True)
    content = db.Column(db.String(96), nullable=False)

    def __repr__(self):
        return f"post id: {self.id}"
Run Code Online (Sandbox Code Playgroud)
# users/models.py

# import sql-alchemy db instance created with factory application
from blog_app import db


class User(db.Model):
    """
    A simple model with a string based column 'name'.
    """
    id = db.Column(db.Integer, primary_key=True)
    name = db.Column(db.String(96), nullable=False)

    def __repr__(self):
        return f"post id: {self.name}"
Run Code Online (Sandbox Code Playgroud)

这些蓝图是帮助保持路由模块化的对象,以及我如何能够创建 User 和 Post 包,其中包含与应用程序特定部分相关的所有模块。例如,包将具有模型、将与视图连接的 url 路由,以及最终呈现动态 HTML 的模板。

Flask 应用程序对象是使用在以下位置找到的应用程序工厂函数创建的blog_app/__init__.py

# blog_app/__init__.py

# Import package dependencies

from flask import Flask
from flask_sqlalchemy import SQLAlchemy
from flask_migrate import Migrate

# Global libraries
db = SQLAlchemy()
migrate = Migrate()


def create_app():
    """Initialize core application."""
    app = Flask(__name__, instance_relative_config=False)
   """
    Configure application from Config class in project-level 
    config.py module.
   """

    app.config.from_object('yourconfig.Config')

    # Initialize plugins
    db.init_app(app)
    migrate.init_app(app, db)

    with app.app_context():
        from blog_app.posts import routes as posts_routes
        from blog_app.users import routes as users_routes

        # Register Blueprints
        app.register_blueprint(posts_routes.post_bp)
        app.register_blueprint(users_routes.user_bp)

    return app
Run Code Online (Sandbox Code Playgroud)

从模板访问路由:

<a href="{{ url_for('posts_bp.posts') }}">Posts</a>
Run Code Online (Sandbox Code Playgroud)