在哪里用 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 已添加到 apiapi 也在文件夹 apisrest 中定义。

#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在这里举个例子:

Link