在烧瓶中创建自定义命令
原文:https://www . geesforgeks . org/creating-custom-commands-in-flask/
本文围绕如何在 flask 中创建自定义命令展开。每次使用烧瓶运行运行烧瓶时,运行实际上是一个命令,在烧瓶配置文件中启动一个名为运行的函数。同样,如果您曾经使用过类似 flask migrate 的东西,那么您可能对 flask DB migrate 或升级很熟悉。要创建这样一个在后端执行一些操作的手动命令,我们将遵循一些步骤–
如何在 Flask 中创建自定义命令?
**第 1 步:**使用两个主库创建命令–单击并使用烧瓶的 _appcontext 库。现在让我们创建一个名为“烧瓶创建”的命令,该命令将启动一个数据库,并在该数据库中创建一个简单的表
import click
from flask.cli import with_appcontext
点击是 flask 用来在命令行创建这些命令的库。
步骤 2: 添加数据库配置–
from flask_sqlalchemy import SQLAlchemy
app.config['SQLALCHEMY_DATABASE_URI']="sqlite://db.sqlite3"
**第三步:**然后我们创建一个简单的表格,如图所示:
class MyTable(db.Model):id = db.Column(db.Integer, primary_key=True)
所以这个表显然不会做任何事情,它只有一列,因为本文的目的是演示如何创建一个命令,所以无论何时您想首先创建一个命令,您都可以使用装饰器**@ click . command(name = ’ create ')**(这里参数的值告诉您想要创建的自定义命令的名称)。
**@ with _ app context()–**with _ app context 将所有的 app 信息都放在这个函数中,所以这个函数被称为包含在 app 中。
**步骤 4–**让我们创建所需的文件
蟒蛇 3
# import required libraries
from flask import Flask
import click
from flask.cli import with_appcontext
from flask_sqlalchemy import SQLAlchemy# initialize flask app
app = Flask(__name__)# initialize Database configuration
app.config['SQLALCHEMY_DATABASE_URI'] = 'sqlite://db.sqlite3'# create Database
db = SQLAlchemy(app)# add table to Database
class MyTable(db.Model):id = db.Column(db.Integer, primary_key=True)# create command function
@click.command(name='create')
@with_appcontext
def create():db.create_all()# add command function to cli commands
app.cli.add_command(create)
运行烧瓶前创建–
运行烧瓶创建后–
数据库中的表格–