creating-custom-commands-in-flask

在烧瓶中创建自定义命令

原文:https://www . geesforgeks . org/creating-custom-commands-in-flask/

本文围绕如何在 flask 中创建自定义命令展开。每次使用烧瓶运行 运行烧瓶时,运行实际上是一个命令,在烧瓶配置文件中启动一个名为运行的函数。同样,如果您曾经使用过类似 flask migrate 的东西,那么您可能对 flask DB migrate 或升级很熟悉。要创建这样一个在后端执行一些操作的手动命令,我们将遵循一些步骤--

如何在 Flask 中创建自定义命令?

**第 1 步:**使用两个主库创建命令--单击并使用烧瓶的 _appcontext 库。现在让我们创建一个名为"烧瓶创建"的命令,该命令将启动一个数据库,并在该数据库中创建一个简单的表

py 复制代码
import click
from flask.cli import with_appcontext

点击是 flask 用来在命令行创建这些命令的库。

步骤 2: 添加数据库配置--

py 复制代码
from flask_sqlalchemy import SQLAlchemy
app.config['SQLALCHEMY_DATABASE_URI']="sqlite://db.sqlite3"

**第三步:**然后我们创建一个简单的表格,如图所示:

py 复制代码
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

py 复制代码
# 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)

运行烧瓶前创建--

运行烧瓶创建后--

数据库中的表格--

相关推荐
加油吧zkf6 分钟前
AI大模型如何重塑软件开发流程?——结合目标检测的深度实践与代码示例
开发语言·图像处理·人工智能·python·yolo
t_hj7 分钟前
python规划
python
Java技术小馆8 分钟前
GitDiagram如何让你的GitHub项目可视化
java·后端·面试
czhc114007566323 分钟前
Linux 76 rsync
linux·运维·python
星星电灯猴32 分钟前
iOS 性能调试全流程:从 Demo 到产品化的小团队实战经验
后端
程序无bug41 分钟前
手写Spring框架
java·后端
JohnYan43 分钟前
模板+数据的文档生成技术方案设计和实现
javascript·后端·架构
悠悠小茉莉1 小时前
Win11 安装 Visual Studio(保姆教程 - 更新至2025.07)
c++·ide·vscode·python·visualstudio·visual studio
全干engineer1 小时前
Spring Boot 实现主表+明细表 Excel 导出(EasyPOI 实战)
java·spring boot·后端·excel·easypoi·excel导出
Da_秀1 小时前
软件工程中耦合度
开发语言·后端·架构·软件工程