全部。我使用Flask,SQLAlchemy和connexion编写项目。在实现连接之前,所有工作都成功完成(以应用程序创建为app = Flask(__name__)
时的提示。实现连接后,会引发异常:
'SQLALCHEMY_DATABASE_URI' not in app.config and AttributeError: 'FlaskApp' object has no attribute 'config'
。那么哪里有错误呢?请帮助。
run.py:
from app import create_app
app = create_app('development')
if __name__ == '__main__':
app.run()
app:
...
from settings import app_config
db = SQLAlchemy()
def create_app(config_name):
# app = Flask(__name__)
app = connexion.App(__name__)
app.add_api('swagger.yml')
application = app.app
application.config.from_object(app_config[config_name])
application.config['SQLALCHEMY_TRACK_MODIFICATIONS'] = False
db.init_app(app)
return app
settings.py
class BaseConfig(object):
DEBUG = False
CSRF_ENABLED = True
SECRET = os.getenv('SECRET', 'default_secret_key')
DEFAULT_URI = 'postgresql://shooter:shooter@localhost/shooterstats'
SQLALCHEMY_DATABASE_URI = DEFAULT_URI
class DevelopmentConfig(BaseConfig):
DEBUG = True
答案 0 :(得分:1)
这是您可以使用 Connexion 设置 Flask 应用程序的一种方法。
/
?
答案 1 :(得分:0)
这里db.init_app(app)
出错。我将其更改为db.init_app(application),它现在可以成功运行。