URL控制器下的PATH方法
-
Django 2.0中控制器下的re_path就是1.0的url
-
re_path中re_path("^$")是任意字符代表路径除了
?
字符 比如127.0.0.1:8000/IDwbabdbwjai9183121/
-
re_path很明显就是用正则描述路径,但是像下面好几个路径规则都一样,其实可以考虑用path方法
我们可以把re_path("^test/([0-9]{4,})",show_index),
用path("^test/int:year/str:month",show_index)
re_path中的"^test/([0-9]{4,})"
换成"^test/<int:YY>/<str:month>"
-
path中直接用<内置数据类型:变量>进行代替,这个<>的匹配数据就是有名分组,并且提取出来的数据就已经转换成了相应的数据类型
-
path的内置类型
- str- 匹配除路径分隔符之外的任何非空字符串‘/‘。如果转换器未包含在表达式中,则这是默认值。
- int - 匹配零或任何正整数。返回一个int。
- slug - 匹配由ASCII字母或数字组成的任何slug字符串,以及连字符和下划线字符。例如, building-your-1st-django-site。
- uuid - 匹配格式化的UUID。要防止多个URL映射到同一页面,必须包含短划线并且字母必须为小写。例如,075194d3-6885-417e-a8a8-6c931e272f00。返回一个 UUID实例。
- path- 匹配任何非空字符串但是?不行,包括路径分隔符 ‘/‘。这使您可以匹配完整的URL路径,而不仅仅是URL路径的一部分str。
URL控制下PATH自定义转换器
#在项目路由urls中导入register_converter
from django.urls import register_converter
class path_setup:
regex="[0-9]{6,8}" # regex这个变量名是固定的.
#函数名也是固定的
def to_python(self,value): #用于自定义的path
return int(value) #这一步其实可以对参数进行自定义处理.
def to_url(self,value): #to_url主要用于反向解析
return str(value)
#使用前需要用register_converter 进行注册,2个参数分别是自定义的类名和自定义的别名
register_converter(path_setup,"abc")
urlpatterns = [
path("test/<abc:cba>",show_index)
]
view视图的代码
def show_index(request,cba):
# return render(request,"test.html")
return HttpResponse("month=%i"%(cba))