在哪里用 Flask-restplus 初始化 SQLAlchemy 实例
Where to initialize SQLAlchemy instance with Flask-restplus
我遇到了两个模块相互导入的困境。
在这个Flask-restplus应用中,app.py是初始化Flask应用和SQLAlchemy数据库实例的入口点。
import settings
from apis.rest import api
from apis.audio_namespace import ns as audio_namespace
log = logging.getLogger(__name__)
app = Flask(__name__)
app.config["SQLALCHEMY_DATABASE_URI"] = settings.DATABASE
db = SQLAlchemy(app)
def configure_app(flask_app):
flask_app.config['SERVER_NAME'] = settings.FLASK_SERVER_NAME
def initialize_app(flask_app):
configure_app(flask_app)
blueprint = Blueprint('api', __name__, url_prefix='/api')
api.init_app(blueprint)
api.add_namespace(audio_namespace)
flask_app.register_blueprint(blueprint)
def main():
initialize_app(app)
app.run(debug=settings.FLASK_DEBUG)
if __name__ == "__main__":
main()
文件夹 apis
中的命名空间 audio_namespace
已添加到 api
。 api
也在文件夹 apis
的 rest
中定义。
#rest.py
api = Api(version='1.0', title='SoundAPI',
description='API for audio processing with TensorFlow')
audio_namespace.py
处理所有请求,因此处理数据库操作。
ns = api.namespace('audio', description='Audio processing with TensorFlow')
class AudioDAO(object):
@property
def audios(self):
return AudioModel.query.all()
def get(self, id):
audio = AudioModel.query.filter_by(id=id).first()
if audio:
return {"id": audio.id, "filename": audio.file_name}
api.abort(404, "Audio {} doesn't exist".format(id))
def create(self, file_name):
audio = AudioModel(file_name)
audio.insert_ts = datetime.now()
db.session.add(audio)
db.session.commit()
return audio
@ns.route('/upload')
class AudioUpload(Resource):
def put(self):
...........
def post(self):
...........
但是由于 db
是在 app.py
中定义的,所以我必须从 app
导入 db
。因此我收到错误提示 audio_namespace
中的 ns
无法在 app.py
中导入,因为这两个模块无法相互导入。
那我应该在哪里定义db
呢?
我不知道这是否对您有帮助,但您可以尝试在没有应用的情况下实例化 SqlAlchemy,然后创建您的应用并在 initialize_app 和 [=20 中调用 db.init_app(app) =] 你的应用程序在那个方法中。
现在我在移动,所以我不能写代码,我会link在这里举个例子:
我遇到了两个模块相互导入的困境。
在这个Flask-restplus应用中,app.py是初始化Flask应用和SQLAlchemy数据库实例的入口点。
import settings
from apis.rest import api
from apis.audio_namespace import ns as audio_namespace
log = logging.getLogger(__name__)
app = Flask(__name__)
app.config["SQLALCHEMY_DATABASE_URI"] = settings.DATABASE
db = SQLAlchemy(app)
def configure_app(flask_app):
flask_app.config['SERVER_NAME'] = settings.FLASK_SERVER_NAME
def initialize_app(flask_app):
configure_app(flask_app)
blueprint = Blueprint('api', __name__, url_prefix='/api')
api.init_app(blueprint)
api.add_namespace(audio_namespace)
flask_app.register_blueprint(blueprint)
def main():
initialize_app(app)
app.run(debug=settings.FLASK_DEBUG)
if __name__ == "__main__":
main()
文件夹 apis
中的命名空间 audio_namespace
已添加到 api
。 api
也在文件夹 apis
的 rest
中定义。
#rest.py
api = Api(version='1.0', title='SoundAPI',
description='API for audio processing with TensorFlow')
audio_namespace.py
处理所有请求,因此处理数据库操作。
ns = api.namespace('audio', description='Audio processing with TensorFlow')
class AudioDAO(object):
@property
def audios(self):
return AudioModel.query.all()
def get(self, id):
audio = AudioModel.query.filter_by(id=id).first()
if audio:
return {"id": audio.id, "filename": audio.file_name}
api.abort(404, "Audio {} doesn't exist".format(id))
def create(self, file_name):
audio = AudioModel(file_name)
audio.insert_ts = datetime.now()
db.session.add(audio)
db.session.commit()
return audio
@ns.route('/upload')
class AudioUpload(Resource):
def put(self):
...........
def post(self):
...........
但是由于 db
是在 app.py
中定义的,所以我必须从 app
导入 db
。因此我收到错误提示 audio_namespace
中的 ns
无法在 app.py
中导入,因为这两个模块无法相互导入。
那我应该在哪里定义db
呢?
我不知道这是否对您有帮助,但您可以尝试在没有应用的情况下实例化 SqlAlchemy,然后创建您的应用并在 initialize_app 和 [=20 中调用 db.init_app(app) =] 你的应用程序在那个方法中。
现在我在移动,所以我不能写代码,我会link在这里举个例子: