基本環(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)聽的端口號弹渔;
- 用于開發(fā)的服務(wù)器在需要的情況下會對每一次的訪問請求重新載入一遍 Python 代碼观蓄。所以你不需要為了讓修改的代碼生效而頻繁的重新啟動(dòng)服務(wù)器溢吻。然而羹铅,一些動(dòng)作讼撒,比如添加新文件廊宪,將不會觸發(fā)自動(dòng)重新加載族奢,這時(shí)你得自己手動(dòng)重啟服務(wù)器煎娇。
新建app命令:python manage.py startapp app_name
步驟4:在項(xiàng)目下新建 templates 路徑
注意*:
此目錄下即用來存放我們的html文件二庵;
- 此目錄一般是與app的主目錄是平級的。當(dāng)然也可以建立在app的目錄下缓呛,主要取決于你的模板催享,一般是全局使用呢,還是專門服務(wù)于某個(gè)app哟绊;
請務(wù)必查看項(xiàng)目設(shè)置中是否已設(shè)置自動(dòng)檢索此目錄因妙,方法如下:
1. 打開項(xiàng)目中的 settings.py 文件 2. 找到變量 TEMPLATES ,確認(rèn)其鍵名為 DIRS 的鍵值是否為:[os.path.join(BASE_DIR, 'templates')]
步驟5:在項(xiàng)目下新建 static 路徑
- 此目錄下即用來存放我們的靜態(tài)文件:img、css等;
- 此目錄一般是與app的主目錄是平級的攀涵,也可自行選擇目錄铣耘;
- 請務(wù)必查看項(xiàng)目設(shè)置中是否已設(shè)置自動(dòng)檢索此目錄,方法如下:
1. 打開項(xiàng)目中的 settings.py 文件 2. 末尾處新增變量 STATICFILES_DIRS 并賦值為:[os.path.join(BASE_DIR, 'static')]
步驟6:為MTV模型的各文件建立聯(lián)系
6.1 首先理解下Django的MTV模型
我們以 http://127.0.0.1:8000/index 簡單作下說明:
1.用戶提交Request請求:把瀏覽器中url地址提交給Django服務(wù)器
2.Request首先到達(dá)的淡藍(lán)色區(qū)域以故,你可以理解為Django項(xiàng)目中的 urls.py 文件蜗细,在此文件中會去根據(jù)你事先在 urlpatterns 列表中定義好的url路徑去確定 index/ 指向哪個(gè) Views文件,即你編寫好的某個(gè)app目錄下的 views.py 文件
3.views.py 文件中的
函數(shù)render(request,'xxx.html',model_Var)
將會獲取數(shù)據(jù)模型:Models 和 模板網(wǎng)頁:Templates怒详,在三者的共同渲染下炉媒,給客戶端返回 Response,呈現(xiàn)出完整網(wǎng)頁棘利。
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)以上即可以最簡單的構(gòu)造一個(gè)訪問橱野,接下來的步驟將會說明如何使用models.py
步驟7:連接數(shù)據(jù)庫并使用 models.py
7.1 在Django中連接MongoDB數(shù)據(jù)庫
Django 模型是與數(shù)據(jù)庫相關(guān)的,與數(shù)據(jù)庫相關(guān)的代碼一般寫在 models.py 中善玫,Django 支持 sqlite3, MySQL, PostgreSQL,MongoDB等數(shù)據(jù)庫办桨,只需要在settings.py中配置即可吐根,不用更改models.py中的代碼,豐富的API極大的方便了使用。
在 settings.py 中添加設(shè)置:
# 引入mongoengine 以連接MongoDB數(shù)據(jù)庫
from mongoengine import connect
connect('website', host='127.0.0.1', port='27017')
使用的庫為 mongoengine粱坤,其使用文檔詳見:http://docs.mongoengine.org/tutorial.html
7.2 在 models.py 中書寫ORM數(shù)據(jù)模型
from mongoengine import *
# 引入mongoengine 以連接MongoDB數(shù)據(jù)庫
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)
說明:
1.類的定義:可以理解為一個(gè)類就是數(shù)據(jù)庫中文檔(每一行數(shù)據(jù))的模板,因此繼承于Document
2.其中 meta 屬性中淹仑,需要寫明這個(gè)類的指向,即你要訪問哪個(gè)collection中的數(shù)據(jù)
3.使用class.objects
屬性來完成對每個(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)