基本環(huán)境:
- 安裝好pyCharm社區(qū)版
- 使用
pip install Django
安裝好Django
步驟1:使用pyCharm新建項(xiàng)目
步驟2:新建Django項(xiàng)目
命令:django-admin startproject project_name
步驟3:新建項(xiàng)目下的app
理論上這個(gè)時(shí)候如果使用指令python manage.py runserver 8000
即可以成功啟動(dòng)Django內(nèi)置服務(wù)器
注意:
在manage.py文件所在目錄的命令行去使用該指令梨水;
你可以直接再該指令后跟需要監(jiān)聽的端口號(hào);
-
用于開發(fā)的服務(wù)器在需要的情況下會(huì)對(duì)每一次的訪問(wèn)請(qǐng)求重新載入一遍 Python 代碼疫诽。所以你不需要為了讓修改的代碼生效而頻繁的重新啟動(dòng)服務(wù)器。然而旦委,一些動(dòng)作奇徒,比如添加新文件,將不會(huì)觸發(fā)自動(dòng)重新加載缨硝,這時(shí)你得自己手動(dòng)重啟服務(wù)器摩钙。
新建app命令:python manage.py startapp app_name
步驟4:在項(xiàng)目下新建 templates 路徑
注意:
此目錄下即用來(lái)存放我們的html文件;
- 此目錄一般是與app的主目錄是平級(jí)的查辩。當(dāng)然也可以建立在app的目錄下胖笛,主要取決于你的模板网持,一般是全局使用呢,還是專門服務(wù)于某個(gè)app长踊;
請(qǐng)務(wù)必查看項(xiàng)目設(shè)置中是否已設(shè)置自動(dòng)檢索此目錄功舀,方法如下:
- 打開項(xiàng)目中的 settings.py 文件
- 找到變量 TEMPLATES ,確認(rèn)其鍵名為 DIRS 的鍵值是否為:[os.path.join(BASE_DIR, 'templates')]
步驟5:在項(xiàng)目下新建 static 路徑
- 此目錄下即用來(lái)存放我們的靜態(tài)文件:img、css等身弊;
- 此目錄一般是與app的主目錄是平級(jí)的辟汰,也可自行選擇目錄;
- 請(qǐng)務(wù)必查看項(xiàng)目設(shè)置中是否已設(shè)置自動(dòng)檢索此目錄阱佛,方法如下:
- 打開項(xiàng)目中的 settings.py 文件
- 末尾處新增變量 STATICFILES_DIRS 并賦值為:[os.path.join(BASE_DIR, 'static')]
步驟6:為MTV模型的各文件建立聯(lián)系
6.1 首先理解下Django的MTV模型
我們以 http://127.0.0.1:8000/index 簡(jiǎn)單作下說(shuō)明:
1.用戶提交Request請(qǐng)求:把瀏覽器中url地址提交給Django服務(wù)器
2.Request首先到達(dá)的淡藍(lán)色區(qū)域帖汞,你可以理解為Django項(xiàng)目中的 urls.py 文件上渴,在此文件中會(huì)去根據(jù)你事先在 urlpatterns 列表中定義好的url路徑去確定 index/ 指向哪個(gè) Views文件粹懒,即你編寫好的某個(gè)app目錄下的 views.py 文件
3.views.py 文件中的函數(shù)render(request,'xxx.html',model_Var)
將會(huì)獲取數(shù)據(jù)模型:Models 和 模板網(wǎng)頁(yè):Templates,在三者的共同渲染下债沮,給客戶端返回 Response麦萤,呈現(xiàn)出完整網(wǎng)頁(yè)鹿鳖。
6.2 具體方法
(1)在urls.py 文件中添加路徑
from django.contrib import admin
from django.urls import path
from blog.views import index
urlpatterns = [
path('admin/', admin.site.urls),
path('index/', index),
]
(2)在views.py 文件中構(gòu)造render(request,templates,model)
函數(shù)
from django.shortcuts import render
def index(request):
return render(request, 'index.html')
(3)以上即可以最簡(jiǎn)單的構(gòu)造一個(gè)訪問(wèn),接下來(lái)的步驟將會(huì)說(shuō)明如何使用models.py
步驟7:連接數(shù)據(jù)庫(kù)并使用 models.py
7.1 在Django中連接MongoDB數(shù)據(jù)庫(kù)
Django 模型是與數(shù)據(jù)庫(kù)相關(guān)的壮莹,與數(shù)據(jù)庫(kù)相關(guān)的代碼一般寫在 models.py 中翅帜,Django 支持 sqlite3, MySQL, PostgreSQL,MongoDB等數(shù)據(jù)庫(kù),只需要在settings.py中配置即可命满,不用更改models.py中的代碼涝滴,豐富的API極大的方便了使用。
在 settings.py 中添加設(shè)置:
# 引入mongoengine 以連接MongoDB數(shù)據(jù)庫(kù)
from mongoengine import connect
connect('website', host='127.0.0.1', port='27017')
使用的庫(kù)為 mongoengine胶台,其使用文檔詳見:http://docs.mongoengine.org/tutorial.html
7.2 在 models.py 中書寫ORM數(shù)據(jù)模型
from mongoengine import *
# 引入mongoengine 以連接MongoDB數(shù)據(jù)庫(kù)
from mongoengine import connect
connect('ganji', host='127.0.0.1', port=27017)
#定義類
class Info(Document):
cate_name = StringField()
person = StringField()
title = StringField()
cate = StringField()
post_time = StringField()
datetime = StringField()
position = StringField()
phone = StringField()
url = StringField()
price = IntField()
meta = {
'collection': 'info_list2'
}
#展示數(shù)據(jù)
for i in Info.objects[:1]:
print(i.cate_name)
說(shuō)明:
1.類的定義:可以理解為一個(gè)類就是數(shù)據(jù)庫(kù)中文檔(每一行數(shù)據(jù))的模板歼疮,因此繼承于Document
2.其中 meta 屬性中,需要寫明這個(gè)類的指向,即你要訪問(wèn)哪個(gè)collection中的數(shù)據(jù)
3.使用class.objects
屬性來(lái)完成對(duì)每個(gè)文檔的遍歷
4.class.objects
支持切片操作
步驟8:在views.py中使用models.py 中的數(shù)據(jù)模型
from django.shortcuts import render
# 從app模塊導(dǎo)入blog中的model文件诈唬,使用其中的Info類
from blog.models import Info
def index(request):
# 類的實(shí)例化操作
info=Info.objects[:1]
context = {
'info': {
'title': info[0].cate_name,
'author': info[0].person,
'des': info[0].title,
}
}
return render(request, 'index.html', context)
步驟9:使用Django中的templates語(yǔ)法在網(wǎng)頁(yè)中使用數(shù)據(jù)
轉(zhuǎn)載于:http://www.reibang.com/p/ea7632c32d63