该
flask命令是使用创建的Click界面
flask.cli.FlaskGroup。创建您自己的组并将其传递给工厂功能。使用
app.shell_context_processor对象添加到外壳。
from flask import Flaskfrom flask.cli import FlaskGroupfrom flask_sqlalchemy import SQLAlchemydb = SQLAlchemy()def create_app(script_info=None): app = Flask(__name__) db.init_app(app) ... @app.shell_context_processor def shell_context(): return {'app': app, 'db': db} return appcli = FlaskGroup(create_app=create_app)@cli.commanddef custom_command(): passif __name__ == '__main__': cli()运行文件而不是
flask命令。您将使用工厂获得Click界面。
FLASK_DEBUG=1 python app.py run
理想情况下,创建一个入口点并将软件包安装在环境中。然后,您可以将脚本作为命令来调用。
setup.py至少使用以下内容创建一个文件。
project/ app/ __init__.py setup.pyfrom setuptools import setup, find_packagessetup( name='my_app', version='1.0.0', packages=find_packages(), entry_points={ 'console_scripts': [ 'app=app:cli', ], },)pip install -e /path/to/projectFLASK_DEBUG=1 app run与内置
flask命令相比,使用自己的CLI的鲁棒性较弱。因为您的
cli对象是用其他代码定义的,所以模块级错误将导致重新加载器失败,因为它无法再导入该对象。该
flask命令与您的项目分开,因此不受模块错误的影响。



