Flask Script扩展提供向Flask插入外部脚本的功能,包括运行一个开发用的服务器,一个定制的Python shell,设置数据库的脚本,cronjobs,及其他运行在web应用之外的命令行任务;使得脚本和系统分开;
Flask Script和Flask本身的工作方式类似,只需定义和添加从命令行中被Manager实例调用的命令;
官方文档:
1 创建并运行命令
首先,创建一个Python模板运行命令脚本,可起名为manager.py;
在该文件中,必须有一个Manager实例,Manager类追踪所有在命令行中调用的命令和处理过程的调用运行情况;
Manager只有一个参数——Flask实例,也可以是一个函数或其他的返回Flask实例;
调用manager.run()启动Manager实例接收命令行中的命令;
#-*-coding:utf8-*- from flask_script import Manager from debug import app manager = Manager(app) if __name__ == '__main__': manager.run()
其次,创建并加入命令;
三中创建命令的方式:创建Command子类、使用@command修饰符、使用@option修饰符
一、创建Command子类
Command子类必须定义一个run方法
举例:创建Hello命令,并将Hello命令加入Manager实例
from flask_script import Manager ,Serverfrom flask_script import Command from debug import app manager = Manager(app) class Hello(Command): 'hello world' def run(self): print 'hello world' #自定义命令一:manager.add_command('hello', Hello()) # 自定义命令二:manager.add_command("runserver", Server()) #命令是runserverif __name__ == '__main__': manager.run() """执行如下命令:python manager.py hello> hello world python manager.py runserver > hello world"""
二、使用@command修饰符
#-*-coding:utf8-*- from flask_script import Manager from debug import app manager = Manager(app) @manager.command def hello(): 'hello world' print 'hello world' if __name__ == '__main__': manager.run() """python manager.py hello> hello world"""
三、使用@option修饰符
复杂情况下,建议使用@option;
可以有多个@option选项参数;
使用flask-script自定义的manage.py文件
#!/usr/bin/env python# -*- coding:utf-8 -*-import osfrom flask_script import Manager, Serverfrom app import create_appapp = create_app()manager = Manager(app)@manager.commanddef custom(arg): """ 自定义命令 python manage.py custom 123 :param arg: :return: """ print(arg)@manager.option('-n', '--name', dest='name')@manager.option('-u', '--url', dest='url')def cmd(name, url): """ 自定义命令 执行: python manage.py cmd -n wupeiqi -u http://www.oldboyedu.com :param name: :param url: :return: """ print(name, url)@manager.commanddef import_news(path): """ 批量导入 :param name: :param url: :return: """ import xlrd from xlrd.book import Book from xlrd.sheet import Sheet from xlrd.sheet import Cell workbook = xlrd.open_workbook(path) sheet_names = workbook.sheet_names() # sheet = workbook.sheet_by_name('工作表1') sheet = workbook.sheet_by_index(0) # 循环Excel文件的所有行 for row in sheet.get_rows(): # print(row) # 循环一行的所有列 for col in row: # 获取一个单元格中的值 print(col.value,end=';') print('')# 自定义命令manager.add_command("runserver", Server())if __name__ == "__main__": manager.run()