我的应用布局
my_app
__init__.py
my_app
__init__.py
startup
__init__.py
create_app.py
create_users.py
common_settings.py
core
__init__.py
models.py
views.py
errors
__init__.py
errors.py
内部__init __。py
from flask import Flask
from flask_script import Manager
from flask_sqlalchemy import SQLAlchemy
app = Flask(__name__) # The WSGI compliant web application object
db = SQLAlchemy(app) # Setup Flask-SQLAlchemy
manager = Manager(app) # Setup Flask-Script
from my_app.startup.create_app import create_app
create_app()
create_app.py
def create_app(extra_config_settings={}):
# Load all blueprints with their manager commands, models and views
from my_app import core
return app
芯/ __初始化__。PY
# from . import views
views.py
from my_app import app, db
from flask import Flask, request
@app.errorhandler(Error)
def handle_invalid_usage(error):
response = jsonify(data=error.to_dict())
response.status_code = error.status_code
return response
我将此代码基于我找到的教程。只要我将核心文件夹中的__init__.py
留空,一切正常。
如果不这样做,我的NameError: name Error is not defined
会收到views.py
。 Error
来自errors.py
。
我有三个问题:
1)为什么只有在{strong> core / __ init __。py 中留下import
语句时才会发生这种情况。
2)
create_app.py
app.config.from_envvar('ENV_SETTINGS_FILE')
# Other app.config commands here
from my_app import core
return app
from my_app import core
运行时会发生什么?
3)最后,当我return app
时,这是否确保内部__init __。py 文件包含更新的app
对象?
非常感谢任何解释!
答案 0 :(得分:0)
尝试使用动态导入构建和配置应用程序确实是个坏消息,并且因为您发现的原因而感到困惑。一个更好,更容易理解的模式将是一个更典型的工厂:
def create_app():
app = Flask(__name__)
configure_app(app, config)
register_db(app)
add_views(app)
add_manager(app)
return app
if __name__ == '__main__':
app = create_app()
app.run()
但是既然你问,你的问题就在这里:
from my_app import app, db
from flask import Flask, request
@app.errorhandler(Error) # Error is not imported
def handle_invalid_usage(error):
response = jsonify(data=error.to_dict())
response.status_code = error.status_code
return response
发生错误是因为导入了views.py
,代码编译器遇到Error
并且无法找到对它的引用。
对于您的第二个问题:from my_app import core
导致core.__init.__
运行,这可能(可能)将视图添加到应用对象。