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

Flask 第五课 -- 项目结构

目录

一. 前言

二. 简单项目结构

三. 中型项目结构

四. 复杂项目结构


一. 前言

一个 Flask 应用可以简单到只有一个文件。

比如以下 hello.py 文件就是一个 Flask 应用:

from flask import Flask

app = Flask(__name__)


@app.route('/')
def hello():
    return 'Hello, World!'

然而,当项目变大时,把所有代码都放到一个文件里不太现实。

Flask 项目结构可以根据应用的规模和复杂性有所不同。

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

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

二. 简单项目结构

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

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

my_flask_app 目录下的 app.py 文件代码:

from flask import Flask

app = Flask(__name__)

@app.route('/')
def home():
    return 'Hello, World!'

if __name__ == '__main__':
    app.run(debug=True)

requirements.txt 示例:

Flask==2.2.3

三. 中型项目结构

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

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 Flask

def create_app():
    app = Flask(__name__)
    app.config.from_object('config.Config')

    from . import routes
    app.register_blueprint(routes.bp)

    return app

app/routes.py 示例:

from flask import Blueprint

bp = Blueprint('main', __name__)

@bp.route('/')
def home():
    return 'Hello, World!'

run.py 示例:

from app import create_app

app = create_app()

if __name__ == '__main__':
    app.run(debug=True)

四. 复杂项目结构

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

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_template

bp = Blueprint('main', __name__)

@bp.route('/')
def home():
    return render_template('home.html')

app/models/user.py 示例:

from app import db

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

http://www.kler.cn/a/301941.html

相关文章:

  • 测试实项中的偶必现难测bug--互斥逻辑异常
  • 黑盒测试案例设计方法的使用(1)
  • Spring boot + Vue2小项目基本模板
  • 【2025最新计算机毕业设计】基于SpringBoot+Vue电脑在线装机指南教程网站【源码+文档】
  • 鸿蒙北向开发 : hdmfs-分布式文件系统
  • 探索SAP财务管理软件:重塑企业财务管理新境界
  • 零基础5分钟上手亚马逊云科技-利用API网关管理API
  • 移植案例与原理 - XTS子系统之应用兼容性测试用例开发
  • 在Ubuntu 20.04上安装pgAdmin 4
  • 【Linux】探索进程优先级的奥秘,解锁进程的调度与切换
  • ICM20948 DMP代码详解(17)
  • Mysql查看锁阻塞信息
  • 机器学习实战21-基于XGBoost算法实现糖尿病数据集的分类预测模型及应用
  • 用钱能解决的事儿真不叫事儿!
  • SQL Server数据库简单的事务日志备份恢复
  • arcgis Feature Server的新增、更新、删除
  • 从边缘到云端,合宙DTURTU打造无缝物联网解决方案
  • AI学习指南深度学习篇-Adam在深度学习中的应用
  • Linux和C语言(Day07)
  • uniapp实现下拉刷新
  • 什么是数据库回表,又该如何避免
  • 简单比较 http https http2,我们要如何把http升级为https
  • UML-统一建模语言学习笔记20240912
  • 性能测试-跨线程组使用变量(十四)
  • 【网络安全】对称密码体制
  • Android 10.0 mtk平板camera2横屏预览旋转90度横屏拍照图片旋转90度功能实现