Django 프로젝트 작업 디렉토리 구조 최적의 관행

2024-07-27

Django 프로젝트 작업 디렉토리 구조 최적의 관행

프로젝트 루트 디렉토리

프로젝트 루트 디렉토리는 프로젝트의 모든 주요 구성 요소를 포함하는 중앙 디렉토리입니다. 프로젝트 루트 디렉토리에는 다음과 같은 파일과 디렉토리가 포함되어야 합니다.

  • manage.py: Django 관리 스크립트
  • README.md: 프로젝트에 대한 문서
  • LICENSE: 프로젝트 라이센스
  • requirements.txt: 프로젝트에 필요한 Python 패키지 목록
  • venv 또는 .venv: 가상 환경 디렉토리 (선택 사항)

앱 디렉토리

앱 디렉토리는 프로젝트의 기능을 구성하는 별도의 모듈을 포함합니다. 각 앱 디렉토리에는 다음과 같은 파일과 디렉토리가 포함되어야 합니다.

  • __init__.py: 앱을 Python 패키지로 등록하는 파일
  • models.py: 앱의 데이터 모델을 정의하는 파일
  • views.py: 앱의 뷰 함수를 정의하는 파일
  • urls.py: 앱의 URL 패턴을 정의하는 파일
  • migrations 디렉토리: 앱의 데이터 마이그레이션을 저장하는 디렉토리
  • tests 디렉토리: 앱의 테스트를 저장하는 디렉토리 (선택 사항)

정적 파일 디렉토리

정적 파일 디렉토리는 CSS, JavaScript 및 이미지와 같은 정적 파일을 포함합니다. 정적 파일 디렉토리는 다음과 같은 서브 디렉토리로 구성될 수 있습니다.

  • css: CSS 파일
  • js: JavaScript 파일
  • images: 이미지 파일

미디어 파일 디렉토리는 사용자 업로드 파일과 같은 미디어 파일을 포함합니다.

다음과 같은 기타 디렉토리를 프로젝트에 추가할 수 있습니다.

  • docs: 문서 및 자습서
  • scripts: 프로젝트를 자동화하는 데 사용되는 스크립트
  • logs: 프로젝트 로그

최적의 관행

  • 프로젝트 루트 디렉토리를 간결하게 유지하고 불필요한 파일이나 디렉토리를 추가하지 마십시오.
  • 각 앱에 대한 별도의 디렉토리를 사용하십시오.
  • 정적 파일과 미디어 파일을 위한 별도의 디렉토리를 사용하십시오.
  • 의미 있는 이름으로 디렉토리와 파일을 명명하십시오.
  • 버전 관리 시스템(예: Git)을 사용하여 코드를 추적하십시오.

추가 참조

한국어 자료

참고:

  • 이 문서는 Django 프로젝트 작업 디렉토리 구조에 대한 일반적인 권장 사항을 제공합니다. 프로젝트의 특정 요구 사항에 따라 이러한 권장 사항을 조정해야 할 수도 있습니다.
  • 이 문서는 2024년 6월 24일 기준으로 작성되었습니다.



Django 프로젝트 디렉토리 구조 예제

project_root
├── LICENSE
├── README.md
├── manage.py
├── requirements.txt
├── venv
├── myproject
│   ├── __init__.py
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
├── apps
│   ├── blog
│   │   ├── __init__.py
│   │   ├── admin.py
│   │   ├── apps.py
│   │   ├── migrations
│   │   │   ├── 0001_initial.py
│   │   │   └── __init__.py
│   │   ├── models.py
│   │   ├── tests.py
│   │   └── views.py
│   └── polls
│       ├── __init__.py
│       ├── admin.py
│       ├── apps.py
│       ├── migrations
│       │   ├── 0001_initial.py
│       │   └── __init__.py
│       ├── models.py
│       ├── tests.py
│       └── views.py
├── static
│   ├── css
│   │   └── style.css
│   └── js
│       └── script.js
├── media
│   └── images
│       └── logo.png
└── docs
    └── tutorial.md

이것은 간단한 예일 뿐이며, 실제 프로젝트는 더 많은 디렉토리와 파일을 포함할 수 있습니다.

설명:

  • project_root: 프로젝트의 루트 디렉토리입니다.
  • LICENSE: 프로젝트 라이센스를 포함하는 파일입니다.
  • README.md: 프로젝트에 대한 문서를 포함하는 파일입니다.
  • manage.py: Django 관리 스크립트를 포함하는 파일입니다.
  • myproject: 프로젝트의 설정 및 주요 코드를 포함하는 디렉토리입니다.
    • settings.py: 프로젝트의 설정을 정의하는 파일입니다.
    • wsgi.py: WSGI 호환 웹 서버를 위한 엔트리 포인트를 제공하는 파일입니다.
  • apps: 프로젝트의 앱을 포함하는 디렉토리입니다.
    • polls: 설문 조사 앱을 포함하는 디렉토리입니다. (위의 blog 앱과 동일한 구조)
  • static: CSS, JavaScript 및 이미지와 같은 정적 파일을 포함하는 디렉토리입니다.
    • css: CSS 파일을 포함하는 디렉토리입니다.
      • style.css: 프로젝트의 기본 CSS 파일입니다.
    • js: JavaScript 파일을 포함하는 디렉토리입니다.
      • script.js: 프로젝트의 기본 JavaScript 파일입니다.
  • media: 사용자 업로드 파일과 같은 미디어 파일을 포함하는 디렉토리입니다.
    • images: 이미지 파일을 포함하는 디렉토리입니다.
      • logo.png: 프로젝트 로고 이미지입니다.
  • docs: 문서 및 자습서를 포함하는 디렉토리입니다.
    • tutorial.md: 프로젝트 사용 방법에 대한 자습서입니다.



Django 프로젝트 디렉토리 구조의 대체 방법

평평한 구조

평평한 구조에서는 모든 앱을 프로젝트 루트 디렉토리에 직접 배치합니다. 이 구조는 다음과 같은 경우 유용할 수 있습니다.

  • 작고 단순한 프로젝트를 작업하는 경우
  • 앱 간의 긴밀한 결합이 필요한 경우
project_root
├── LICENSE
├── README.md
├── manage.py
├── requirements.txt
├── venv
├── __init__.py
├── settings.py
├── urls.py
├── wsgi.py
├── apps
│   ├── blog
│   │   ├── __init__.py
│   │   ├── admin.py
│   │   ├── apps.py
│   │   ├── migrations
│   │   │   ├── 0001_initial.py
│   │   │   └── __init__.py
│   │   ├── models.py
│   │   ├── tests.py
│   │   └── views.py
│   └── polls
│       ├── __init__.py
│       ├── admin.py
│       ├── apps.py
│       ├── migrations
│       │   ├── 0001_initial.py
│       │   └── __init__.py
│       ├── models.py
│       ├── tests.py
│       └── views.py
├── static
│   ├── css
│   │   └── style.css
│   └── js
│       └── script.js
├── media
│   └── images
│       └── logo.png
└── docs
    └── tutorial.md

기능별 구조

project_root
├── LICENSE
├── README.md
├── manage.py
├── requirements.txt
├── venv
├── features
│   ├── accounts
│   │   ├── __init__.py
│   │   ├── admin.py
│   │   ├── apps.py
│   │   ├── migrations
│   │   │   ├── 0001_initial.py
│   │   │   └── __init__.py
│   │   ├── models.py
│   │   ├── tests.py
│   │   └── views.py
│   └── products
│       ├── __init__.py
│       ├── admin.py
│       ├── apps.py
│       ├── migrations
│       │   ├── 0001_initial.py
│       │   └── __init__.py
│       ├── models.py
│       ├── tests.py
│       └── views.py
├── static
│   ├── css
│   │   └── style.css
│   └── js
│       └── script.js
├── media
│   └── images
│       └── logo.png
└── docs
    └── tutorial.md

Onion 구조

Onion 구조에서는 핵심 기능을 프로젝트 루트 디렉토리에 배치하고, 외부 기능은 별도의 레이어로 배치합니다. 이 구조는 다음과 같은 경우 유용할 수 있습니다.

  • 핵심 기능과 외부 기능을 명확하게 구분해야 하는 경우
project_root
├── LICENSE
├── README.md
├── manage.py
├── requirements.txt
├── venv
├── core
│   ├── __init__.py
│   ├── settings.py
│   ├── urls.py
│   └── wsgi.py
├── apps
│   ├── accounts
│   │   ├── __init__.py
│   │   ├── admin.py
│   │   ├── apps.py
│   │   ├── migrations
│   │   │   ├── 0001_initial.py
│   │   │   └── __init__.py
│   

django directory-structure organization



Django 사용자 지정 폼에서 시간/날짜 위젯 사용

1. 위젯 선택Django는 다양한 시간/날짜 위젯을 제공합니다. 가장 일반적으로 사용되는 위젯은 다음과 같습니다.SelectDateWidget: 드롭다운 메뉴를 사용하여 날짜를 선택할 수 있습니다.SelectTimeWidget: 드롭다운 메뉴를 사용하여 시간을 선택할 수 있습니다...


Django에서 URL 생성 방법

1. urls. py 파일 사용:Django 프로젝트의 urls. py 파일은 URL 패턴을 정의하는 데 사용됩니다. 각 패턴은 URL과 요청을 처리할 뷰 함수를 연결합니다. 기본적인 URL 패턴은 다음과 같습니다...


Django에서 User 모델을 확장하는 가장 좋은 방법

Django에서 User 모델을 확장하는 방법은 여러 가지가 있습니다.1. 프로필 모델 사용가장 일반적인 방법은 프로필 모델을 사용하는 것입니다. 프로필 모델은 User 모델과 일대일 관계를 갖는 별도의 모델입니다...


대규모 Django 프로젝트를 위한 프로젝트 설계 및 파일 시스템 레이아웃

프로젝트 설계Django 프로젝트를 위한 일반적인 프로젝트 설계에는 다음과 같은 몇 가지 주요 구성 요소가 포함됩니다.루트 프로젝트 디렉토리: 이 디렉토리는 프로젝트의 모든 주요 구성 요소를 포함합니다. 일반적으로 project_name이라는 이름을 갖습니다...


Django 세션 프로그래밍 (Python, Django)

Django 세션은 웹사이트 방문자의 상태를 추적하는 데 사용되는 강력한 도구입니다. 로그인 상태, 쇼핑 카트 항목, 사용자 선호도와 같은 정보를 저장하는 데 사용할 수 있습니다. 세션은 쿠키를 사용하여 클라이언트 측에서 저장되므로 여러 페이지를 방문하더라도 정보가 유지됩니다...



django directory structure organization

Django 클래스 뷰 프로그래밍 개요 (Python, Django, View)

클래스 뷰는 다음과 같은 장점을 제공합니다.코드 재사용성 향상: 공통 로직을 한 번 작성하고 상속을 통해 여러 뷰에서 재사용할 수 있습니다.코드 가독성 향상: 뷰 로직이 명확하게 구분되어 코드를 이해하기 쉽습니다.유지 관리 용이성 향상: 코드 변경이 필요할 경우 한 곳만 변경하면 모든 관련 뷰에 영향을 미칠 수 있습니다


Django 모델에서 MySQL ENUM 유형 필드를 지정하는 방법

1. 필요한 모듈 가져오기:2. ENUM 선택 목록 정의:3. 모델 클래스 정의:설명:MY_ENUM_CHOICES 튜플은 유효한 ENUM 값 목록을 정의합니다. 각 튜플 요소는 값과 해당 값의 표시 문자열로 구성됩니다


Django를 위한 최신 및 빠른 서버 설정 (Python, Django, Apache 활용)

본 가이드에서는 Python, Django, Apache를 사용하여 Django 웹 애플리케이션을 위한 최신かつ 빠른 서버 설정 방법을 단계별로 안내합니다. 이 설정은 성능, 확장성 및 보안을 위해 최적화되어 있으며


Django 템플릿을 사용하여 트리 구조(재귀적)를 렌더링하는 방법

1. 재귀 템플릿 사용이 방법은 트리 구조를 재귀적으로 탐색하고 각 노드에 대한 템플릿을 렌더링하는 데 기반합니다. 다음은 재귀 템플릿을 사용하여 트리 구조를 렌더링하는 방법의 예입니다.이 예에서는 tree. html 템플릿은 각 노드의 이름과 자식 노드가 있는 경우 자식 노드 목록을 렌더링합니다


Django 템플릿 및 변수 속성 (Python, Django, Google App Engine)

템플릿 변수는 템플릿에서 값을 표시하는 데 사용되는 특수 문자입니다. 템플릿 변수는 다음과 같이 {{ }} 로 표시됩니다.예를 들어, 다음 템플릿은 "Hello, John!"라는 문자열을 출력합니다.여기서 name은 템플릿에 전달된 변수 이름입니다