以下是Django2.0版本
正則捕獲到的參數都是字符串,所以如果函數需要用的其他數據類型,可以在函數中直接轉換,也可以在路由中直接轉換,如下:
下面實例是匹配整數,傳過去的參數就是整數
from django.urls import path,re_path
path('admin/<int:year>,view.year.archive') ===>匹配到一個整數變量
Django默認支持以下5個轉化器:
- str,匹配除了路徑分隔符(
/
)之外的非空字符串,這是默認的形式 - int,匹配正整數,包含0。
- slug,匹配字母、數字以及橫杠、下划線組成的字符串。
- uuid,匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00。
- path,匹配任何非空字符串,包含了路徑分隔符(/)(不能用問號,因為問號在url地址有特殊含義。)
1.path
path的第一個參數不能用正則
path其實就是封裝了五種精准的正則匹配(五個轉換器),我們也可以自己定義方法。===》(int,str,slug,path,uuid)
自定義轉換器:
regex
類屬性,字符串類型
to_python(self, value)
方法,value是由類屬性regex
所匹配到的字符串,返回具體的Python變量值,以供Django傳遞到對應的視圖函數中。to_url(self, value)
方法,和to_python
相反,value是一個具體的Python變量值,返回其字符串,通常用於url反向引用。
1 寫一個類:
class Test:
regex = '[0-9]{4}'
def to_python(self, value):
# 中間寫一堆處理
value=value+'aaa'
return value
def to_url(self, value): # 反向解析時候用到
return '%04d' % value
# 和path,re_path在一個模塊里
2 from django.urls import register_converter
# 括號里跟兩個參數,第一個自定義的類 第二個是自定義的轉換器類型
用register_converter
將其注冊到URL配置中
3 register_converter(Test,'ttt')
4 path('index/<ttt:year>', views.index,name='index'),
2.re_path
和Django1.1版本中的url用法相同,url地址可以用正則。
re_path (r'^admin/(?P<name>\w{3})$',views.admin)
二 MVC和MTV
MVC :M 模型 V 模板 C 控制器(路由+views)
MTV:M 模型 T template V views
三 視圖層
form表單,不寫method 默認GET請求
1 什么情況用GET :請求數據,請求頁面
1.什么情況用POST:向服務器提交數據,用GET會泄露數據,不懂技術的人也能看到
request.GET 得到的是一個封裝的字典:QueryDict
request.POST 得到的是一個封裝的字典:QueryDict
獲得請求的方式(類型):request.method
http://127.0.0.1:8000/index/ppp/dddd/?name=lqz
協議:ip地址和端口/路徑?參數(數據)
print(request.path) 獲得的是不包括數據的請求
print(request.get_full_path()) 獲得的是整個url 包括數據請求
三件套:HttpResponse、redirect、render
from django.shortcuts import 三件套
JsonResponse(向前端頁面發送json格式字符串)
# dic={'name':'lqz','age':18}
# li=[1,2,3,4]
# # return HttpResponse(json.dumps(li))
# from django.http import JsonResponse
# 加safe是因為jsonResponse有安全保護不能直接向前端發送json格式字符串,所以要設置成False
# return JsonResponse(li,safe=False)
四 CBV(class base view)和FBV(function base view)
CBV 和FBV基於類的視圖和基於函數的視圖
CBV:
1 from django.views import View
2 class Test(View):
def dispatch(self, request, *args, **kwargs):
# 加點東西
print('111')
obj=super().dispatch(request, *args, **kwargs)
# 加點東西
print('2222')
return obj
def get(self,request):
obj= render(request,'index.html')
print(type(obj))
return obj
def post(self,request):
return HttpResponse('ok')
3 re_path(r'index/', views.Test.as_view()), # 這兒是固定寫法
簡單文件上傳
index.html
1 <form action="" method="post" enctype="multipart/form-data">
用戶名:<input type="text" name="name">
密碼:<input type="text" name="password">
文件:<input type="file" name="myfile">
<input type="submit">
</form>
#enctype="multipart/form-data"******************* 這個是上傳文件必須要加的
#<input type="file" name="myfile"> # 如果寫了這個enctype但是沒有上傳文件,打印的request.FILES.get()會有瀏覽器配置等內容。
2 # ff是一個文件對象,django封裝的
ff=request.FILES.get('myfile')
# 文件對象的名字
file_name=ff.name # 上傳的文件名字。
from django.core.files.uploadedfile import InMemoryUploadedFile # 導入這個類 chunks是這個類的方法
print(type(ff))
with open(file_name,'wb') as f: # chunks是一個生成器,通過yield不斷把值給讀出來。
for line in ff.chunks(): # chunks是文件對象的方法,相當於斷點續傳。為什么不能直接in ff:直接寫入:因為ff是一個對象,不是一個文件
f.write(line)