当前位置: 首页 > news >正文

Flask 项目结构

一个 Flask 应用可以简单到只有一个文件。然而,当项目变大时,把所有代码都放到一个文件里不太现实。Flask 项目结构可以根据应用的规模和复杂性有所不同。

以下是几种常见的 Flask 项目结构,分别适用于简单应用和较复杂的应用:

  • 简单项目结构:适用于小型应用,所有代码集中在一个文件中。
  • 中型项目结构:将应用分为多个模块,便于管理和扩展。
  • 复杂项目结构:支持更高的模块化,适用于大型应用,包含路由、模型、模板和静态文件目录。

简单项目结构

对于一个简单的 Flask 应用,项目结构可以非常简洁:

my_flask_app/
│
├── app.py
└── requirements.txt
  • app.py:主要的 Flask 应用文件,包含路由和视图函数的定义。
  • requirements.txt:列出项目的依赖库,用于记录 Flask 和其他包的版本信息。

提取requirements.txt方法

如果在虚拟环境中开发:pip freeze > requirements.txt

中型项目结构

对于稍复杂的应用,通常会将项目分为多个模块和目录:

my_flask_app/
│
├── app/
│   ├── __init__.py
│   ├── routes.py
│   └── models.py
│
├── config.py
├── requirements.txt
└── run.py
  • app/:包含 Flask 应用的主要代码。
    • __init__.py:初始化 Flask 应用和配置扩展。
    • routes.py:定义应用的路由和视图函数。
    • models.py:定义应用的数据模型。
  • config.py:配置文件,包含应用的配置信息。
  • requirements.txt:列出项目的依赖库。
  • run.py:用于启动 Flask 应用。

app/__init__.py 示例:

from flask import Flaskdef create_app():app = Flask(__name__)app.config.from_object('config.Config')from . import routesapp.register_blueprint(routes.bp)return app

app/routes.py示例:

from flask import Blueprintbp = Blueprint('main', __name__)@bp.route('/')
def home():return 'Hello, World!'

run.py 示例:

from app import create_appapp = create_app()if __name__ == '__main__':app.run(debug=True)

复杂项目结构

对于较大的应用,可能需要更复杂的项目结构,以支持更高的模块化和扩展性:

Blueprint: Flask 提供的一种用于组织大型应用的模块化工具(例如,把不同功能的路由、视图函数分开)。

my_flask_app/
│
├── app/
│   ├── __init__.py
│   ├── routes/
│   │   ├── __init__.py
│   │   ├── main.py
│   │   └── auth.py
│   ├── models/
│   │   ├── __init__.py
│   │   └── user.py
│   ├── templates/
│   │   ├── layout.html
│   │   └── home.html
│   └── static/
│       ├── css/
│       └── js/
│
├── config.py
├── requirements.txt
├── migrations/
│   └── ...
└── run.py
  • app/routes/:将不同功能模块的路由分开管理。
    • main.py:主模块的路由。
    • auth.py:认证相关的路由。
  • app/models/:管理数据模型,通常与数据库操作相关。
    • user.py:用户模型。
  • app/templates/:存放 HTML 模板文件。
  • app/static/:存放静态文件,如 CSS 和 JavaScript。
  • migrations/:数据库迁移文件,通常与 SQLAlchemy 相关。

app/routes/main.py 示例:

from flask import Blueprint, render_templatebp = Blueprint('main', __name__)@bp.route('/')
def home():return render_template('home.html')

app/models/user.py 示例:

from app import dbclass User(db.Model):id = db.Column(db.Integer, primary_key=True)username = db.Column(db.String(150), unique=True, nullable=False)

代码解释

bp = Blueprint('main', __name__)

创建了一个蓝图对象 bp
'main': 蓝图的名称,用于后期注册到主应用区分不同蓝图
__name__: 代表当前模块的名字,用于 Flask 查找模板或静态文件的路径。

http://www.dtcms.com/a/281948.html

相关文章:

  • Flask的基本概念
  • Ray集群部署与维护
  • 显示器如何突破 DisplayPort 1.4 的带宽限制,显示更高的分辨率刷新率
  • 网络劫持对用户隐私安全有何影响?
  • python fonttools字体多语言解析
  • iOS 上架被拒 4.3a 【Cocos全面解读】
  • iOS App 上架流程优化指南 工具组合与常见问题处理经验总结
  • 用AI做带货视频评论分析进阶提分【Datawhale AI 夏令营】
  • 插板式系统的“生命线“:EtherCAT分布式供电该如何实现?
  • RoMa: Robust Dense Feature Matching论文精读(逐段解析)
  • docker 安装rabbitmq
  • 【C#】实体类定义的是long和值识别到的是Int64,实体类反射容易出现Object does not match target type
  • 【电脑】显示器的基础知识
  • 微服务相关问题(2)
  • 【前端Vue】this.resetForm(“form“)重置表单时出现indexOf报错的解决方案
  • GraphQL与REST在微服务接口设计中的对比分析与实践
  • Vue 3 中调用子组件方法
  • Linux-局域网构建+VLAN 划分 + 端口 MAC-IP 绑定 + 静态 DHCP
  • 基于MATLAB的k近邻KNN的数据分类预测方法应用
  • ArcGISPro应用指南:使用ArcGIS Pro创建与优化H3六边形网格
  • 深度剖析 TDMQ RabbitMQ 版经典队列底层存储机制
  • 【C# in .NET】11. 探秘泛型:类型参数化革命
  • C++ 面向对象
  • 滚珠导轨在封装设备如何体现高精度运行?
  • 创建linux端口映射连接小网
  • 基于CentOS的分布式GitLab+Jenkins+Docker架构:企业级CI/CD流水线实战全记录
  • 如何选择适合的云手机配置?解决资源不足带来的性能瓶颈
  • Clip微调系列:《coOp: learning to prompt for vision-language models》
  • 蓝光三维扫描技术:手机闪光灯模块全尺寸3D检测的高效解决方案
  • Clip微调系列:《CLIP-Adapter: Better Vision-Language Models with FeatureAdapters》