【Django】基于Django架构网站代码的目录结构---转载
經(jīng)典的Django項(xiàng)目源碼目錄結(jié)構(gòu)
?Django在一個項(xiàng)目的目錄結(jié)構(gòu)劃分方面缺乏必要的規(guī)范。在Django的官方文檔中并沒有給出大型項(xiàng)目的代碼建議目錄結(jié)構(gòu),網(wǎng)上的文章也是根據(jù)項(xiàng)目的不同結(jié)構(gòu)也有適當(dāng)?shù)淖兓?/p>
樣式一 :強(qiáng)調(diào)模塊化設(shè)計??參見參考文章二
··管理項(xiàng)目的依賴文件requirements文件夾,列出項(xiàng)目中需要的依賴的文件,比如項(xiàng)目使用的所有python包。
··分離應(yīng)用文件和庫文件(apps ,libs)新建apps和libs用來保存application和library
··創(chuàng)建完善的setting模塊
優(yōu)勢:模塊化設(shè)計適合規(guī)模較大的項(xiàng)目
?缺點(diǎn):這種布局結(jié)構(gòu)沒有說明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.txt10 directories, 36 files?
樣式二,大型開源Django框架項(xiàng)目的?參見參考文章5
?此模板是開源項(xiàng)目常用的結(jié)構(gòu),適合大型Django項(xiàng)目開發(fā)。
Project的目錄結(jié)構(gòu),PROJ_NAME指的是項(xiàng)目名
PROJ_NAME/__init__.py 這幾個文件是django創(chuàng)建project所必須的,不做過多說明manage.pysettings.pyurls.py apps/ 即使是“小”工程,也建議分成多個app,每個app足夠簡單,只解決某一個方面的問題 (注1)myapp1/myapp2/extra_apps/ 引用的其他app。libs/ 加載第三方模塊,可以避免版本沖突,按照標(biāo)準(zhǔn)的site-packages管理(注2)python*.*/ 指定python版本號site-packages/ requirements.pip #pip的依賴說明文件tests/ project級別的測試,對于每個app,還要有自己的測試代碼static/ 靜態(tài)內(nèi)容css/js/images/uploads/ 上傳文件所在目錄templates/ 模板目錄,覆蓋app的模板flatpages/comments/example/app1/app2/templatetags/ tag目錄注1:指定app加載,在settings.py中設(shè)置:
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中設(shè)置:
sys.path.insert(0, '/{{MY_LIB)}/site-packages/*****.egg')sys.path.insert(0, '/{{MY_LIB}} /site-packages/')
其中 app目錄結(jié)構(gòu)
$APP_NAME/tests/ app級別的測試代碼models/ 注1__init__.pyAmodels.pyBmodels.pytemplates/ 注2templatetags/ tag目錄?
注1:如果很好的控制app的規(guī)模,Model類數(shù)量少,可以使用慣用的models.py文件中, 否則將models做成一個package
接下來可以有兩種做法:
1. 在__init__.py中import所有的Model類
2. 指定Model的元類(Meta)的app_label, 參考這里
注2:如果extend 工程下的base.html, 使用 !base.html
?
?我的總結(jié)
?···樣式一中強(qiáng)調(diào)的“Think Modular”思想十分適合大型的項(xiàng)目,大部分大型的項(xiàng)目也是遵循模塊化目錄結(jié)構(gòu)的原則的。
如下圖所示:?
-project---app1--templates--staticsviewsmodelstestsurls---app2---appnstatics--css--jssettings?
?
···我在開源項(xiàng)目上看到的小型Project的目錄結(jié)構(gòu)差異較大,沒有清晰的體系結(jié)構(gòu),規(guī)律不是很明顯。
?
參考文章
1?Large Django application layout
2?重要Django project structure? 基于Django 1.4 project
3?Project design / FS layout for large django projects [closed]
4?Django官網(wǎng)提供的大型開源項(xiàng)目
5?重要?Django最佳實(shí)踐:項(xiàng)目布局? ?| ??python開源項(xiàng)目目錄結(jié)構(gòu)
6?AN UPDATED GENERAL DJANGO PROJECT (>= 1.5) STRUCTURE OR FOLDER LAYOUT
7?Google小組上關(guān)于目錄結(jié)構(gòu)的討論
轉(zhuǎn)載于:https://www.cnblogs.com/winstonsias/p/11544179.html
總結(jié)
以上是生活随笔為你收集整理的【Django】基于Django架构网站代码的目录结构---转载的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: Hadoop常用操作汇总
- 下一篇: Django model、view拆分,