【Flask项目】项目准备之-Flask-Script说明

在人生的道路上,不管是潇洒走一回,或者是千山独行,皆须是自己想走的路,虽然,有的人并不是很快就能找到自己的方向和道路,不过,只要坚持到底,我相信,就一定可以找到自己的路,只要找到路,就不必怕路途遥远了。

导读:本篇文章讲解 【Flask项目】项目准备之-Flask-Script说明,希望对大家有帮助,欢迎收藏,转发!站点地址:www.bmabk.com,来源:原文

1、Flask-Script介绍

Flask-Script的作用是可以通过命令行的形式来操作Flask。
Flask Script扩展提供向Flask插入外部脚本的功能,包括运行一个开发用的服务器,一个定制的Python shell,设置数据库的脚本,cronjobs,及其他运行在web应用之外的命令行任务;使得脚本和系统分开;

安装

pip install flask-script

2、Flask-Script基本使用

在一个在flask项目中,新建一个新的hello.py,其中的hello功能函数我们希望通过命令来运行。

from flask_script import Manager
from shop import app_config

app=app_config('develop')

#第一步:初始化manage对象
manage=Manager(app)

#第二步:通过命令执行
@manage.command
def hello():
    print('命令执行成功')


if __name__ == '__main__':
	#第三步:启动manage
    manage.run()

特别注意:当前的命令调用flask要和web主程序分离,管理员偶尔会用到,用户不会用到
在这里插入图片描述
执行命令:
不要启动项目主程序
在这里插入图片描述

3、Flask-Script案例

需求:通过命令直接在数据库中创建一个用户
数据库连接配置config.py文件
首先:执行以下代码创建表

#当前的命令调用flask要和web主程序分离,管理员偶尔会用到,用户不会用到

from flask_script import Manager
from shop import app_config
from flask_sqlalchemy import SQLAlchemy

app=app_config('develop')

manage=Manager(app)

db=SQLAlchemy(app)

class User(db.Model):
    __tablename__ = 't_user1'
    id = db.Column(db.Integer,primary_key=True,autoincrement=True)
    uname = db.Column(db.String(50),nullable=False)
    pwd = db.Column(db.String(50),nullable=False)
    age = db.Column(db.Integer,nullable=True)

db.create_all()

@manage.command
def hello():
    print('命令执行成功')


if __name__ == '__main__':
    manage.run()

然后添加数据到数据表中

#当前的命令调用flask要和web主程序分离,管理员偶尔会用到,用户不会用到

from flask_script import Manager
from shop import app_config
from flask_sqlalchemy import SQLAlchemy

app=app_config('develop')

manage=Manager(app)

db=SQLAlchemy(app)

class User(db.Model):
    __tablename__ = 't_user1'
    id = db.Column(db.Integer,primary_key=True,autoincrement=True)
    uname = db.Column(db.String(50),nullable=False)
    pwd = db.Column(db.String(50),nullable=False)

#db.create_all()

@manage.command
def hello():
    print('命令执行成功')

#通过命令直接在数据库中创建一个用户
@manage.option('-u','--username',dest='uname')
@manage.option('-p','--password',dest='pwd')
def create_user(uname,pwd):
    user=User(uname=uname,pwd=pwd)
    db.session.add(user)
    db.session.commit()
    print('添加用户成功!')

if __name__ == '__main__':
    manage.run()

执行代码:
在这里插入图片描述
或者:
在这里插入图片描述

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/123371.html

(0)
飞熊的头像飞熊bm

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!