經典的Django項目源碼目錄結構css
Django在一個項目的目錄結構劃分方面缺少必要的規範。在Django的官方文檔中並無給出大型項目的代碼建議目錄結構,網上的文章也是根據項目的不一樣結構也有適當的變化。html
樣式一 :強調模塊化設計 參見參考文章二python
··管理項目的依賴文件requirements文件夾,列出項目中須要的依賴的文件,好比項目使用的全部python包。django
··分離應用文件和庫文件(apps ,libs)新建apps和libs用來保存application和libraryapp
··建立完善的setting模塊框架
優點:模塊化設計適合規模較大的項目模塊化
缺點:這種佈局結構沒有說明static文件的放置路徑。佈局
$ tree . . ├── djangolicious │ ├── apps │ │ ├── blog │ │ │ ├── __init__.py │ │ │ ├── models.py │ │ │ ├── tests.py │ │ │ └── views.py │ │ ├── __init__.py │ │ ├── news │ │ │ ├── __init__.py │ │ │ ├── models.py │ │ │ ├── tests.py │ │ │ └── views.py │ │ └── reader │ │ ├── __init__.py │ │ ├── models.py │ │ ├── tests.py │ │ └── views.py │ ├── __init__.py │ ├── libs │ │ ├── display │ │ │ ├── __init__.py │ │ │ ├── models.py │ │ │ ├── tests.py │ │ │ └── views.py │ │ ├── __init__.py │ │ └── management │ │ ├── __init__.py │ │ ├── models.py │ │ ├── tests.py │ │ └── views.py │ ├── settings │ │ ├── common.py │ │ ├── dev.py │ │ ├── __init__.py │ │ ├── prod.py │ │ └── test.py │ ├── urls.py │ └── wsgi.py ├── manage.py ├── requirements │ ├── common.txt │ ├── dev.txt │ ├── prod.txt │ └── test.txt └── requirements.txt 10 directories, 36 files
此模板是開源項目經常使用的結構,適合大型Django項目開發。測試
Project的目錄結構,PROJ_NAME指的是項目名ui
PROJ_NAME/ __init__.py 這幾個文件是django建立project所必須的,不作過多說明 manage.py settings.py urls.py apps/ 即便是「小」工程,也建議分紅多個app,每一個app足夠簡單,只解決某一個方面的問題 (注1) myapp1/ myapp2/ extra_apps/ 引用的其餘app。 libs/ 加載第三方模塊,能夠避免版本衝突,按照標準的site-packages管理(注2) python*.*/ 指定python版本號 site-packages/ requirements.pip #pip的依賴說明文件 tests/ project級別的測試,對於每一個app,還要有本身的測試代碼 static/ 靜態內容 css/ js/ images/ uploads/ 上傳文件所在目錄 templates/ 模板目錄,覆蓋app的模板 flatpages/ comments/ example/ app1/ app2/ templatetags/ tag目錄
注1:指定app加載,在settings.py中設置:
sys.path.insert(0, os.path.join(PROJECT_ROOT, 'apps'))
sys.path.insert(0, os.path.join(PROJECT_ROOT, 'extras'))
sys.path.insert(0, os.path.join(PROJECT_ROOT, 'libs'))
注2:自定義libs的加載,在settings.py中設置:
sys.path.insert(0, '/{{MY_LIB)}/site-packages/*****.egg')
sys.path.insert(0, '/{{MY_LIB}} /site-packages/')
$APP_NAME/ tests/ app級別的測試代碼 models/ 注1 __init__.py Amodels.py Bmodels.py templates/ 注2 templatetags/ tag目錄
注1:若是很好的控制app的規模,Model類數量少,可使用慣用的models.py文件中, 不然將models作成一個package
接下來能夠有兩種作法:
1. 在__init__.py中import全部的Model類
2. 指定Model的元類(Meta)的app_label, 參考這裏
注2:若是extend 工程下的base.html, 使用 !base.html
個人總結
···樣式一中強調的「Think Modular」思想十分適合大型的項目,大部分大型的項目也是遵循模塊化目錄結構的原則的。
以下圖所示:
-project ---app1 --templates --statics views models tests urls ---app2 ---appn statics --css --js settings
···我在開源項目上看到的小型Project的目錄結構差別較大,沒有清晰的體系結構,規律不是很明顯。
參考文章
1 Large Django application layout
2 重要Django project structure 基於Django 1.4 project
3 Project design / FS layout for large django projects [closed]
5 重要 Django最佳實踐:項目佈局 | python開源項目目錄結構
6 AN UPDATED GENERAL DJANGO PROJECT (>= 1.5) STRUCTURE OR FOLDER LAYOUT