Django目录结构最佳实践

Django项目目录结构

项目目录结构

python 复制代码
└── backend         # 后端项目目录(项目名称)
    ├── __init__.py
    ├── logs         # 项目日志目录
    ├── manage.py    # 项目启动文件
    ├── scripts      # 保存项目运维的脚本文件 bash
    │   └── __init__.py
    └── backend     # 项目主应用(项目名称)
        ├── apps     # 存放项目中所有自定义app
        │   └── __init__.py
        ├── asgi.py
        ├── __init__.py
        ├── libs              # 第三方类库的保存目录[第三方组件、模块](包)
        │   └── __init__.py
        ├── settings
        │   ├── dev.py         # 开发环境本地配置文件
        │   ├── __init__.py
        │   ├── prod.py        # 生产环境本地配置文件
        │   └── test.py        # 测试环境本地配置文件
        ├── settings.py
        ├── urls.py            # 项目总路由,总入口 
        ├── utils          # 多个模块[子应用]的公共函数类库[自己开发的组件]
        │   └── __init__.py
        └── wsgi.py

配置文件引用修改

将settins.py文件修改为dev或其他环境得本地配置文件时需修改项目管理文件中得配置文件引用

打开manage.py

python 复制代码
原 os.environ.setdefault("DJANGO_SETTINGS_MODULE", "backend.settings")
修改后 os.environ.setdefault("DJANGO_SETTINGS_MODULE", "backend.settings.dev")

创建自定义子应用方法

举例:创建一个home子应用

python 复制代码
cd backend/apps
python ../../manage.py startapp home

修改自定义注册目录从apps目录开始

settings.dev.py

python 复制代码
import sys
BASE_DIR = Path(__file__).resolve().parent.parent
# 注意要放在dev.py(本地配置文件)最上面
sys.path.insert(0, str(BASE_DIR / 'apps'))
INSTALLED_APPS = [
    "django.contrib.auth",
    "django.contrib.contenttypes",
    "django.contrib.sessions",
    "django.contrib.messages",
    "django.contrib.staticfiles",
    "rest_framework",
    # 自己的app
    "home",
]
python 复制代码
import sys
BASE_DIR = Path(__file__).resolve().parent.parent
sys.path.insert(0, str(BASE_DIR / 'apps'))

通过这样调整后,后续我们在本地配置文件中注册子应用时以及在路由视图中导入子应用的路由时就不需要再写apps目录,直接写子应用名称即可,再次强调这些目录配置要写在本地配置文件最上面

相关推荐
ETLCloud数据集成社区4 分钟前
ETLCloud是如何通过Oracle实现CDC的?
数据库·oracle·etl·实时数据同步
KATA~21 分钟前
解决MyBatis-Plus枚举映射错误:No enum constant问题
java·数据库·mybatis
xyliiiiiL36 分钟前
一文总结常见项目排查
java·服务器·数据库
shaoing38 分钟前
MySQL 错误 报错:Table ‘performance_schema.session_variables’ Doesn’t Exist
java·开发语言·数据库
用户62799471826239 分钟前
南大通用GBase 8s 获取表的约束与索引列信息
数据库
Arbori_262151 小时前
获取oracle表大小
数据库·oracle
王强你强1 小时前
MySQL 高级查询:JOIN、子查询、窗口函数
数据库·mysql
草巾冒小子1 小时前
brew 安装mysql,启动,停止,重启
数据库·mysql
用户6279947182621 小时前
南大通用GBase 8c分布式版本gha_ctl 命令-HI参数详解
数据库
斯汤雷1 小时前
Matlab绘图案例,设置图片大小,坐标轴比例为黄金比
数据库·人工智能·算法·matlab·信息可视化