【python】flask各种版本的项目,终端命令运行方式的实现

在这里插入图片描述

✨✨ 欢迎大家来到景天科技苑✨✨

🎈🎈 养成好习惯,先赞后看哦~🎈🎈

🏆 作者简介:景天科技苑
🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN新星创作者,掘金优秀博主,51CTO博客专家等。
🏆《博客》:Python全栈,前后端开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi,flask等框架,linux,shell脚本等实操经验,网站搭建,面试宝典等分享。

所属的专栏:flask框架零基础,进阶应用实战教学
景天的主页:景天科技苑

文章目录

  • 终端脚本命令
    • flask1.0时代的终端命令使用
      • 安装命令
      • 自定义终端命令
    • flask2.0以后版本的终端命令使用
      • 使用flask终端命令之前,可以配置2个环境变量。
      • 查看支持的命令
      • Click自定义终端命令
      • 实战案例
    • 总结

终端脚本命令

flask在0.11版本之前都是采用flask-script第三方模块来实现终端脚本命令的执行,flask在0.11版本以后不再使用这个模块了,因为存在兼容性问题,所以内置了Click模块来实现终端脚本命令的执行。

flask1.0时代的终端命令使用

注意python3.9已不再支持flask1的版本,如果要运行flask1,就需要安装python3.8或以下版本

flask-script模块的作用可以让我们通过终端来控制flask项目的运行,类似于django的manage.py

官方文档:https://flask-script.readthedocs.io/en/latest/

安装命令

conda create -n py38 python=3.8
conda activate py38
pip install -U flask==1.1.4
pip install -U flask-script -i https://pypi.douban.com/simple

集成 Flask-Script到flask应用中,创建一个主应用程序,一般我们叫manage.py/run.py/main.py都行。

manage.py,代码:

from flask import Flas app = Flask(__name__)"""使用flask_script启动项目"""
from flask_script import Manager
manage = Manager(app)@app.route('/')
def index():return 'hello world'if __name__ == "__main__":manager.run()

启动终端脚本的命令:

# 端口和域名不写,默认为127.0.0.1:5000
python manage.py runserver# 通过-h设置启动域名,-p设置启动端口 -d
python manage.py runserver -h0.0.0.0 -p8888     # 关闭debug模式
python manage.py runserver -h0.0.0.0 -p8888  -d # 开启debug模式# 进入flask交互终端,在这个终端下,可以直接调用flask代码进行测试。
python manage.py shell

安装flask==1.1.4版本启动项目时,如果出现错误如下:
from markupsafe import soft_unicode

则找到报错代码位置,修改如下:
from markupsafe import soft_str as soft_unicode

自定义终端命令

Flask-Script 还可以为当前应用程序添加脚本命令

  1. 引入Command命令基类
    from flask_script import Command
  2. 创建命令类必须直接或间接继承Command,并在内部实现run方法或者__call__()方法,
    同时如果有自定义的其他参数,则必须实现get_options方法或者option_list属性来接收参数
  3. 使用flask_script应用对象manage.add_command对命令类进行注册,并设置调用终端别名。

manage.py,代码:

from flask import Flaskapp = Flask(__name__)"""使用flask_script管理项目"""
from flask_script import Manager
manager = Manager(app)from abc import ABC
from flask_script import Command, Optionclass PrintCommand(Command, ABC):"""命令的相关描述: 打印数据"""def get_options(self):# 必须返回选项return (# Option('简写选项名', '参数选项名', dest='变量名', type=数据类型, default="默认值"),Option('-h', '--host', dest='host', type=str, default="127.0.0.1"),Option('-p', '--port', dest='port', type=int, default=8000),Option('-d', '--debug', dest='debug', type=bool, default=False))# 也可以使用option_list来替代get_options# option_list = (#     Option('-h', '--host', dest='host', type=str, default="127.0.0.1"),#     Option('-p', '--port', dest='port', type=int, default="7000"),#     Option('-d', '--debug', dest='debug', type=bool, default=False)# )# 没有flask的应用实例对象---->app对象# def run(self, host, port, debug):#     print("测试命令")#     print(f"self.host={host}")#     print(f"self.port={port}")#     print(f"self.debug={debug}")def __call__(self, app, host, port, debug):  # 会自动传递当前flask实例对象进来print(f"测试命令,{app}")print(f"self.host={host}")print(f"self.port={port}")print(f"self.debug={debug}")# manage.add_command("终端命令名称", 命令类)
manager.add_command("print", PrintCommand)  # python manage.py print@app.route("/")
def index():return "ok"if __name__ == '__main__':manager.run()

使用效果:
在这里插入图片描述

(flask) moluo@ubuntu:~/Desktop/flaskdemo$ python manage.py print -h 0.0.0.0 -p 8000
测试命令
self.host=0.0.0.0
self.port=8000
self.debug=False

(flask) moluo@ubuntu:~/Desktop/flaskdemo$ python manage.py print -h 0.0.0.0 -p 8000 -d true
测试命令
self.host=0.0.0.0
self.port=8000
self.debug=True

(flask) moluo@ubuntu:~/Desktop/flaskdemo$ python manage.py print -h 0.0.0.0 -d true
测试命令
self.host=0.0.0.0
self.port=8000
self.debug=True

(flask) moluo@ubuntu:~/Desktop/flaskdemo$ python manage.py print --host=0.0.0.0 -debug=true
测试命令
self.host=0.0.0.0
self.port=8000
self.debug=True

flask2.0以后版本的终端命令使用

flask0.11.0版本以后,flask内置了一个Click模块,这个模块是终端命令模块,可以让我们直接通过Click的装饰器,编写和运行一些终端命令。
在flask2.0版本已经不能兼容flask-script模块了,所以需要改成使用Click模块来运行和自定义管理终端命令了。

安装了flask2.0以后,当前项目所在的python环境就提供了一个全局的flask命令,这个flask命令是Click提供的。

要使用Click提供的终端命令flask,必须先在环境变量中声明当前flask项目的实例对象所在的程序启动文件。

例如:manage.py中使用了 app = Flask(__name__),则manage.py就是程序启动文件

使用flask终端命令之前,可以配置2个环境变量。

#注意,这样配置环境变量,适合mac和linux系统,不适合Windows

# 指定入口文件,开发中入口文件名一般:app.py/run.py/main.py/index.py/manage.py/start.py
export FLASK_APP=manage.py# 指定项目所在环境
export FLASK_DEBUG=True   # 开发环境,开启DEBUG模式
# export FLASK_DEBUG=False    # 生产环境,关闭DEBUG模式

默认情况下,flask命令提供的子命令。

flask routes  # 显示当前项目中所有路由信息
flask run     # 把flask项目运行在内置的测试服务器下
#flask run --host=0.0.0.0 --port=5055
flask shell   # 基于项目的应用上下文提供终端交互界面,可以进行代码测试。

代码:

from flask import Flaskapp = Flask(__name__)@app.route("/")
def index():return "ok"if __name__ == '__main__':app.run()

在这里插入图片描述

终端配置

export FLASK_APP=manage.py
export FLASK_DEBUG=True   # 开发环境,开启DEBUG模式

在这里插入图片描述

查看支持的命令

在这里插入图片描述

#查看下路由信息

flask routes

在这里插入图片描述

#进入shell,在shell中可以执行相关flask代码

flask shell

在这里插入图片描述

#运行

flask run     # 把flask项目运行在内置的测试服务器下

在这里插入图片描述

#指定ip和端口运行

flask run --host=10.10.0.50 --port=5050

在这里插入图片描述

Click自定义终端命令

在终端自定义执行的命令行参数

案例剖析

#自定义终端命令需要导入click
import click
from flask import Flaskapp = Flask(__name__)#注册commond,自定义一个跟在flask后面的命令
@app.cli.command("faker")  # 假设这个用于生成测试数据
#faker后面跟的子命令参数。每个子命令名不能一样
@click.argument("data", type=str, default="user") # 位置参数
@click.argument("position", type=str, default="mysql") # 位置参数
#第一个是参数简写,第二个是详细写全,第三个是函数内部调用的名字,type是类型,default是默认值,help是辅助信息
@click.option('-n', '--number', 'number', type=int, default=1, help='生成的数据量.')  # 选项参数
#我们上面自定义的faker,接子命令执行后,要实现的功能,通过下面这个函数来定义
def faker_command(data, position, number):"""命令的说明文档:添加测试信息"""print("添加测试信息")print(f"数据类型:data={data}")print(f"数据类型:position={position}")print(f"生成数量:number={number}")@app.route("/")
def index():return "ok"if __name__ == '__main__':app.run()

在这里插入图片描述

终端运行,可以看到我们自定义的faker
在这里插入图片描述

flask faker

不写子命令,会打印出默认值
在这里插入图片描述

也可以自定义

flask faker teacher

在这里插入图片描述

指定选项参数

flask faker teacher -n200

在这里插入图片描述

实战案例

大家都知道,Django在终端命令行可以实现创建Django项目,自动创建好相关文件的操作,但是这一功能在flask中是没有集成进去的。
我们通过今天的学的知识可以自己来实现

要求:
flask3.0的终端下,输入 python manage.py startapp home 则可以在当前目录下创建以下目录和文件
项目目录/
└── home
├── views.py
├── models.py
├── documents.py
├── ws.py
├── services.py
├── urls.py
└── tests.py

代码实现:

import click, os
from flask import Flaskapp = Flask(__name__)
# 配置
app.config.update({"DEBUG": False
})@app.cli.command("startapp")
@click.argument("name")
# @click.option('-n', 'name', help='app name')
def startapp(name):"""生成子模块或子应用"""if os.path.isdir(name):print(f"当前{name}目录已存在!请先处理完成以后再创建。")returnos.mkdir(name)open(f"{name}/views.py", "w")open(f"{name}/models.py", "w")open(f"{name}/documents.py", "w")open(f"{name}/ws.py", "w")open(f"{name}/services.py", "w")open(f"{name}/urls.py", "w")open(f"{name}/test.py", "w")print(f"{name}子应用创建完成....")@app.route("/")
def index():return "ok"if __name__ == '__main__':app.run()

在这里插入图片描述

终端调用:
在这里插入图片描述

创建名为home的项目

flask startapp home

在这里插入图片描述

查看创建的文件
在这里插入图片描述

创建名为users的项目:

flask startapp users

在这里插入图片描述

当然,也可以运用模板,在创建文件时,生成指定的模板,感兴趣的朋友试一下吧!

总结

本文讲述了flask1.0和falsk2.0以后的版本在终端脚本命令运行项目的方式,在工作中,我们经常以这种方式运行项目,有用得到的朋友一键三连,flask高阶应用持续更新中!!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/770884.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

XUbuntu22.04之跨平台日历工具(二百二十四)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 优质专栏:Audio工程师进阶系列【原创干货持续更新中……】🚀 优质专栏:多媒…

WSL2 设置桥接模式

文章目录 一、前言二、准备阶段三、环境配置3.1 Type-V管理器环境配置3.2 新增.wslconfig 文件 四、遇到的问题以及解决方案 一、前言 ​ 使用 wsl 的过程中,会出现 WSL 的IP地址 找不到,或者无法和计算机通讯,搞 嵌入式 的话,还…

网络原理(7)——以太网数据帧和DNS协议(数据链路层和应用层)

目录 一、以太网数据帧(数据链路层) 二、DNS协议(域名解析系统,应用层协议) 一、以太网数据帧(数据链路层) 以太网横跨了数据链路层和物理层,这里只做简单介绍,因为普通程序员用不到这一块&am…

浅谈linux下的进程地址空间(虚拟地址/线性地址)

目录 什么是地址空间 - 虚拟地址空间 地址空间是如何设计的 为什么要有地址空间 什么是地址空间? 示例: 运行之后发现:同一个变量,同一个地址,在运行一段时间后,竟然会在同一时间出现两个不同的值&…

阿里云短信平台收费价格表,短信服务优惠0.032元一条

2024年阿里云短信服务优惠价格表,阿里云短信多少钱一条?低至0.01元一条,200条短信仅需2元,最高可领2000条短信免费赠送,短信套餐包2000条、5000条、5万条等均有活动,阿里云百科aliyunbaike.com整理2024年最…

数字乡村战略实施:科技引领农村经济社会全面发展

随着信息技术的快速发展,数字化已经成为推动经济社会发展的重要力量。在乡村振兴战略的大背景下,数字乡村战略的实施成为了引领农村经济社会全面发展的关键。本文将从数字乡村战略的内涵、实施现状、面临挑战及未来展望等方面,探讨科技如何引…

MySQL数据库备份策略与实践详解

目录 引言 一、MySQL数据库备份的重要性 (一)数据丢失的原因 (二)数据丢失的后果 二、MySQL备份类型 (一)根据数据库状态 (二)根据数据的完整性 (三)…

线程的状态:操作系统层面和JVM层面

在操作系统层面,线程有五种状态 初始状态:线程被创建,操作系统为其分配资源。 可运行状态(就绪状态):线程被创建完成,进入就绪队列,参与CPU执行权的争夺。或因为一些原因,从阻塞状态唤醒的线程…

CCF-CSP认证考试 202212-2 训练计划 100分题解

更多 CSP 认证考试题目题解可以前往:CSP-CCF 认证考试真题题解 原题链接: 202212-2 训练计划 时间限制: 1.0s 内存限制: 512.0MB 问题背景 西西艾弗岛荒野求生大赛还有 n n n 天开幕! 问题描述 为了在大赛中取得…

【Linux】进程的基本概念(进程控制块,ps命令,top命令查看进程)

目录 01.进程的基本概念 程序与进程 进程的属性 02.进程控制块(PCB) task_struct的内容分类 组织进程 03.查看进程 ps命令 top指令 在计算机科学领域,进程是一项关键概念,它是程序执行的一个实例,是操作系统的…

Mybatis的核心配置文件

MyBatis的全局配置文件mybatis-config.xml,配置内容如下: properties(属性)settings(全局配置参数)typeAliases(类型别名)typeHandlers(类型处理器)objectFa…

面试知识汇总——垃圾回收器(分代收集算法)

分代收集算法 根据对象的存活周期,把内存分成多个区域,不同区域使用不同的回收算法回收对象。 对象在创建的时候,会先存放到伊甸园。当伊甸园满了之后,就会触发垃圾回收。 这个回收的过程是:把伊甸园中的对象拷贝到F…

【物联网】Qinghub Kafka 数据采集

基础信息 组件名称 : kafka-connector 组件版本: 1.0.0 组件类型: 系统默认 状 态: 正式发布 组件描述:通用kafka连接网关,消费来自kafka的数据,并转发给下一个节点做相关的数据解析。 配置文…

网络七层模型之物理层:理解网络通信的架构(一)

🤍 前端开发工程师、技术日更博主、已过CET6 🍨 阿珊和她的猫_CSDN博客专家、23年度博客之星前端领域TOP1 🕠 牛客高级专题作者、打造专栏《前端面试必备》 、《2024面试高频手撕题》 🍚 蓝桥云课签约作者、上架课程《Vue.js 和 E…

如何忽略Chrome最小字号的限制

通过控制台调整字体大小时,可以发现即便设置了小于12px的字号,也并不会变小,这是因为Chrome默认最小字号为12px。 在Chrome设置中的外观选项卡中可以发现,默认字体是16px。将最小字号改为0,就能随意设置小于12px的字号…

spring boot商城、商城源码 欢迎交流

一个基于spring boot、spring oauth2.0、mybatis、redis的轻量级、前后端分离、防范xss攻击、拥有分布式锁,为生产环境多实例完全准备,数据库为b2b2c设计,拥有完整sku和下单流程的商城 联系: V-Tavendor

文件编辑命令—vim

1.vim vim 是vi的升级版本.vi 文件名(vi方向键用不了) vim 的官方网站 (welcome home : vim online) 自己也说 vim 是一个程序开发工具而不是文字处理软件。 2.安装vim sudo apt install vim 如果出错了:apt update:刷新软件源; 出现"无法获得锁 之类的"sudo rm 文件…

后端常问面经之并发

volatile 关键字 volatile关键字是如何保证内存可见性的?底层是怎么实现的? "观察加入volatile关键字和没有加入volatile关键字时所生成的汇编代码发现,加入volatile关键字时,会多出一个lock前缀指令”lock前缀指令实际上相…

2015年认证杯SPSSPRO杯数学建模D题(第二阶段)城市公共自行车全过程文档及程序

2015年认证杯SPSSPRO杯数学建模 D题 城市公共自行车 原题再现: 城市交通问题直接影响市民的生活和工作。在地形平坦的城市,公共自行车出行系统是一种很好的辅助手段。一般来说,公共自行车出行系统由数据中心、驻车站点、驻车桩、自行车&…

吴恩达深度学习笔记:浅层神经网络(Shallow neural networks)3.1-3.5

目录 第一门课:神经网络和深度学习 (Neural Networks and Deep Learning)第三周:浅层神经网络(Shallow neural networks)3.1 神经网络概述(Neural Network Overview)3.2 神经网络的表示(Neural Network Representation…