url映射的作用 根據Django的MTV模式,url的映射是根據用戶輸入或傳送而來的url路徑,來進行區分去執行相應的view函數來響應用戶的操作。 url映射的方式 Django項目的創建後,會自動創建和你項目名稱相同的全局文件包,urls.py就在其中。 urlpatterns = [ pat ...
url映射的作用
根據Django的MTV模式,url的映射是根據用戶輸入或傳送而來的url路徑,來進行區分去執行相應的view函數來響應用戶的操作。
url映射的方式
Django項目的創建後,會自動創建和你項目名稱相同的全局文件包,urls.py就在其中。
urlpatterns = [
path('admin/', admin.site.urls),
]
這是Django自動添加的一條映射。我們的view函數在自己創建的app中,所以需要先引入app文件包中的views
from blog import views
這樣就可以在urlpatterns中添加自己的映射條件,例如
from blog import views
urlpatterns = [
path('admin/', admin.site.urls),
path('blog/',views.blog)
]
寫相應的視圖函數
from django.shortcuts import render,HttpResponse
def blog(request):
return HttpResponse("WELCOME")
這樣在瀏覽器中輸入127.0.0.1:8000/blog/就能看到返回的WELCOME了。
url映射的函數
urlpatterns中可以使用兩種函數,path()用來字元串路由,re_path()處理正則式路由。
path函數
必須有的參數
path()中有兩個必須填的參數,一個是路徑字元串,一個是所調用的函數。
就如上邊的例子
path('blog/',views.blog)
這個只匹配在你的路徑後加上blog/的情況,然後執行views下的blog函數,表示靜態,精確的映射。
路徑字元串除了填精確的路徑外,還可以填<類型:變數名>,可以在匹配 url的同時傳遞參數,而且匹配的範圍更加龐大。例如:
path('<int:year>/year/',views.year)
可以匹配”任意整型數字/year/“,並且匹配到的整型數字還會以變數名為year的形式作為參數傳遞給views.year函數。這裡註意:views.year函數的參數名必須和你在url映射時起的名字相同,即“year”。
這裡的數據類型還有其他幾種:
數據類型 | 說明 |
---|---|
str | 匹配除分隔符(/)外的非空字元 |
int | 匹配0和正整數 |
slug | 匹配字母、數字、橫杠、下劃線組成的字元串,str的子集 |
uuid | 匹配格式化的UUID,如075194d3-6885-417e-a8a8-6c931e272f00 |
path | 匹配任何非空字元串,包括路徑分隔符,是全集 |
非必要參數
path中的非必要參數也有兩個,一個是用來給視圖函數傳遞的參數,一個是別名。
用來給視圖函數傳遞的參數除了上述直接在url中,還可以手動指定填入path()中,以字典的形式填入,因為這裡的參數類型為**kwargs。而視圖函數中的參數同樣必須和字典中的鍵名相同。例如:
path('<int:year>/year/',views.year,{"name":"sfencs","age":20})
def year(req,year,name,age):
str1=str(year)+" "+name+" "+str(age)
return HttpResponse(str1)
如果url參數和字典類型參數都使用了,並且名稱相同,如:
path('<int:year>/year/',views.year,{"name":"sfencs","year":20})
那麼在視圖函數中只能添加一個year參數,並且在字典中的year的數據20會覆蓋掉url中的數據。
最後一個參數是別名,例如:
path('blog/',views.blog,name="abc")
在html中,form表單提交的路徑就可以使用abc來代替/blog/,具體方式為
<form action="{% url 'alias' %}" method="post">
這種方式只允許在前端中使用,在地址欄中通過使用別名的方式訪問是不起作用的。
re_path()函數
re_path()函數和path()函數類似,但它是使用正則表達式的模式來代替字元串模式進行匹配,只要符合正則式的模式就可以匹配成功。
re_path("^\d+/day/",views.day)
這裡也可以通過url來傳遞參數,使用的是正則式分組的方式
re_path("^(\d+)/day/",views.day)
沒有給分組起名字的模式,即為無命名參數,分組所匹配的數據會自動當參數傳遞給視圖函數,但是視圖函數的形參必須要多寫一個參數,名字任意。
re_path("^(?P<day>\d+)/day/",views.day)
上面這種為命名參數,視圖函數必須以其名字作為參數名,同樣,如果手動添加的參數與其名稱相同,那麼手動添加的參數數據會將正則式中的覆蓋。
路由分發
假如我們一個項目中有多個app,那麼所有的映射都寫到同一個urls.py,或者公用一個url,難免會產生錯誤,產生混淆,那麼我們可以在每個app下建立自己的urls.py來處理自己的映射關係,在全局urls下進行分發。具體方式為:
在全局urls中添加
path('blog/',include('blog.urls'))
在blog文件夾下創建urls.py文件,在文件中寫入
from django.urls import path,re_path
from blog import views
urlpatterns = [
path("login/",views.login)
]
那麼在地址欄中輸入/blog/login,就會先由全局urls分發到blog下的urls,再進行相應的視圖函數映射。
- 最後有一點要註意,所有的url映射都是從上到下按順序匹配,遇到第一個匹配成功後就不在往下進行了。
-
Strom框架基本概念就不提了,這裡主要講的是`Stream`自定義ID的消息流。預設spout、bolt都需實現介面方法`declareOutputFields`,這種情況下發的消息會被所有定義的bolts接收。我們如果需要根據得到的消息類型來選擇不同的bolt,就需要用到Stream Group... ...
-
今天在工作中遇到的幾個小問題,總結一下: 1.因為業務需要調用PHP的介面,獲取到的返回體需要做一段邏輯處理,然而某個欄位接收到的參數是io.serializable類型,欄位的類型不是預期的string類型,當時有點懵逼,因為是用Scala的match case做模式匹配,也沒多想,幸虧同事提示一 ...
-
Storm框架主要分三個Component:topology,spout,bolt。unconfirmedMap對象存儲了MQ所有發射出去等待確認的消息唯一標識deliveryTag,當storm系統回調ack、fail方法後進行MQ消息的成功確認或失敗重回隊列操作(Storm系統回調方法會在bol... ...
-
由於筆者在自己設計CRC模塊時遇到很多問題,在網上並未找到一篇具有實際指導意義的文章,在經過多次模擬修改再模擬之後得到了正確的結果,故願意在本文中為大家提供整個設計流程供大家快速完成設計。本文章主要針對具體的實際應用給出一套親測可行的實現辦法,給出設計代碼並提供模擬結果,供各位參考。 一.CRC概述 ...
-
多線程 thread_local 類型 thread_local變數是C++ 11新引入的一種存儲類型。 thread_local關鍵字修飾的變數具有線程周期(thread duration), 這些變數(或者說對象)線上程開始的時候被生成(allocated), 線上程結束的時候被銷毀(deall ...
-
一、列表推導式 寫點:[結果 for 變數 in 可迭代對象 if 判斷] 二、字典推導式 寫法:[結果 for 變數 in 可迭代對象 if 判斷] 三、集合推導式 寫法:[結果 for 變數 in 可迭代對象 if 判斷] 結論: 推導式比較耗記憶體。一次載入。而生成器表達式幾乎不占用記憶體。使用的 ...
-
一.概述 當你在嘗試一門新的語言時,可能不會過於關註程式出錯的問題, 但當真的去創造可用的代碼時,就不能再忽視代碼中的可能產生的錯誤和異常了。 鑒於各種各樣的原因,人們往往低估了語言對錯誤處理支持程度的重要性。 事實會表明,Scala 能夠很優雅的處理此類問題, 這一部分,我會介紹 Scala 基於 ...
-
證明: ...