django2.0 path使用方法

Django2.0于2017年12月2日已经正式发布。Django2.0支持Python3.4,3.5以及3.6,移除了对Python2.7的支持。官方强烈建议Python 3.x使用最新的版本。

在Django2.0其中一个新特性为:简化Url路由的语法

在代码上主要体现在新增了django.urls.path函数,它带来了更简洁、更可读的路由语法,如:

原来的url

url(r‘^articles/(?P<year>[0-9]{4})/$‘, views.year_archive),

Django2.0新语法

path(‘articles/<int:year>/‘, views.year_archive),

新语法支持url参数的类型转化。例子里的year_archive函数接收到的year参数作为参数,并且会自动转换year为整型而不是字符串。

在Django1.x里,我们需要对year做类型转换:

def year_archive(request, year):
    year = int(year)

URL参数捕获

在新的语法里,url字符串有以下规则:

  1. 在url里使用尖括号“<>”来捕获值
  2. 尖括号捕获值的格式<converter:name>。其中converter为路径转换器,name为参数名,如<int:year>。对于捕获的值没有路径转换器,那么它会匹配除了斜杠"/"外的所有字符作为捕获的值。
  3. url不需要以斜杠开头。

代码示例

from django.urls import path

from . import views

urlpatterns = [
    path(‘articles/2003/‘, views.special_case_2003),
    path(‘articles/<int:year>/‘, views.year_archive),
    path(‘articles/<int:year>/<int:month>/‘, views.month_archive),
    path(‘articles/<int:year>/<int:month>/<slug:slug>/‘, views.article_detail),
]

匹配示例

  • /articles/2005/03/:匹配到第3个规则,调用views.month_archive(request, year=2005, month=3)
  • /articles/2003/:匹配到第1个规则,调用views.special_case_2003(request)
  • /articles/2003:没有匹配到规则,原因是所有的规则都是以斜杠结尾
  • /articles/2003/03/building-a-django-site/:匹配到第4个规则,调用views.article_detail(request, year=2003, month=3, slug=”building-a-django-site”)

Path Converter

url里捕获的值使用Path Converter来对值做转换,如类型转换。Django2.0自带了默人的Path Converter,同时也支持自定义Path Conveter。

默认Path converter

Django2.0自带的PathConveter包括:

  • str:匹配除了路径分隔符(/)之外的非空字符串,如果没有转换器,默认使用str作为转换器。
  • int:匹配0及正整数。
  • slug:匹配字母、数字以及横杠、下划线组成的字符串。
  • uuid:匹配格式化的uuid,如 075194d3-6885-417e-a8a8-6c931e272f00
  • path:匹配任何非空字符串,包含了路径分隔符(/)

例子: path(‘image_codes/<uuid>‘, views.xxxx)  image_codes是前缀,<uuid>是django自带的配合器写法,得到的是一个UUID对象, 在视图方法中通过参数来接受这个 uuid    例如: def get(self,request,uuid) 可以打印这个UUID 得到是一个前端传过来的uuid.

注册自定义Path Converter

当默认的Path Converter不能满足需求时,Django2.0支持用户注册自定义的Path Converter。

Path Converter是一个类,定义Converter类需要包含下面的属性或方法:

  • regex属性,字符串类型
  • to_python(self, value) 方法,它处理将匹配的字符串转换为应该传递给view函数的类型。 如果它不能转换给定的值,它应该抛出ValueError。
  • to_url(self, value) 方法,和 to_python 相反,它会将Python类型转换为在URL中使用的字符串。

示例

定义Path Converter

class FourDigitYearConverter:
    regex = ‘[0-9]{4}‘

    def to_python(self, value):
        return int(value)

    def to_url(self, value):
        return ‘%04d‘ % value

使用register_converter()注册Converter到url配置里:

from django.urls import register_converter, path

from . import converters, views

register_converter(converters.FourDigitYearConverter, ‘yyyy‘)

urlpatterns = [
    path(‘articles/2003/‘, views.special_case_2003),
    path(‘articles/<yyyy:year>/‘, views.year_archive),
    ...
]

正则表达式匹配

Django2.0也支持我们使用正则表达式来捕获值。注意,用正则表达式捕获值,需要使用re_path(),而不是前面介绍的path()。

正则表达式建议使用命名正则表达式组,语法如下:

(?P<name>pattern)

其中,尖括号里的name为分组名,pattern为正则表达式。

前面的示例可以使用正则表达式修改为:

from django.urls import path, re_path

from . import views

urlpatterns = [
    path(‘articles/2003/‘, views.special_case_2003),
    re_path(‘articles/(?P<year>[0-9]{4})/‘, views.year_archive),
    re_path(‘articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/‘, views.month_archive),
    re_path(‘articles/(?P<year>[0-9]{4})/(?P<month>[0-9]{2})/(?P<slug>[\w-_]+)/‘, views.article_detail),
]

与前面的示例不同点:

  • 这里的代码匹配更加严格,比如year为10000就无法匹配,因为它超出了正则规定的4位数
  • 传给view函数的参数为字符串类型,这点和 Django使用url 是一样的。

设置默认值

在path里支持对view设置默认值。


from django.urls import path

from . import views

urlpatterns = [
    path(‘blog/‘, views.page),
    path(‘blog/page<int:num>/‘, views.page),
]

# View (in blog/views.py)
def page(request, num=1):
    # Output the appropriate page of blog entries, according to num.
    ...

page函数num的默认值设置为1.

原文地址:https://www.cnblogs.com/wangdongpython/p/10865442.html

时间: 2024-11-07 12:28:34

django2.0 path使用方法的相关文章

Django2.0版本的path方法无法使用正则表达式的解决办法

本人的django的版本是2.0.6 在django项目中,在urls.py文件中,匹配路由用的path方法,之前我用的都是url方法 写了一个path方法,使用正则表达式 from django.contrib import admin from django.urls import path from app1 import views urlpatterns = [ # path('admin/', admin.site.urls), path('test/', views.Test.as

Django2.0路由补充之path,re_path及视图层

以下是Django2.0版本 正则捕获到的参数都是字符串,所以如果函数需要用的其他数据类型,可以在函数中直接转换,也可以在路由中直接转换,如下: 下面实例是匹配整数,传过去的参数就是整数 from django.urls import path,re_path path('admin/<int:year>,view.year.archive') ===>匹配到一个整数变量 Django默认支持以下5个转化器: str,匹配除了路径分隔符(/)之外的非空字符串,这是默认的形式 int,匹配

Django2.0中得url路由path得用法

Django2.0中,url得匹配规则更新了,在django1.0中,url是用正则表达式书写得,相对来说比较繁琐一些,在django2.0中进行了升级优化,改为了path from django.urls import path 导入path模块后,可以使用啦请看截图 原文地址:https://www.cnblogs.com/chaojiyingxiong/p/9693081.html

Django2.0版本 path与Django1.x版本url正则匹配问题

Django1.x版本url正则匹配如下: Django2.0版本正则匹配则要导入re_path模块如下: 原文地址:https://www.cnblogs.com/Dev0ps/p/9890861.html

Django2.0中URL的路由机制

Django2.0中URL的路由机制 路由是关联url及其处理函数关系的过程.Django的url路由配置在settings.py文件中ROOT_URLCONF变量指定全局路由文件名称. Django的路由都写在urls.py文件中的urlpatterns列表中,由path()或re_path()作为元素组成. Django的URL路由流程: 1 Django查找全局urlpatterns变量(urls.py) 2 按照先后顺序,对URL逐一匹配urlpatterns每个元素 3 找到第一个匹配

Python 3之Django2部署(centos7+nginx+python3+django2.0)

前置工具,系统为centos7.5,为了方便管理,可以安装宝塔免费版本 首先, yum install -y wget && wget -O install.sh http://download.bt.cn/install/install_6.0.sh && bash install.sh 正常干净系统会顺利完成安装,使用过程是感觉自己记下配置和更新的过程,类似版本更新或者冲突的先别急着百度,容易造成冲突. 宝塔6.6版本是依赖python2.7的,所以python可以升级

Django2.0 URL配置

一.实例 先看一个例子: from django.urls import path from . import views urlpatterns = [ path('articles/2003/', views.special_case_2003), path('articles/<int:year>/', views.year_archive), path('articles/<int:year>/<int:month>/', views.month_archive

Python3+Django2.0基础入门demo

 1.安装Python3环境 [root@openshift ~]# cat /etc/redhat-release CentOS Linux release 7.4.1708 (Core) 默认为Python2.7,需要安装Python3 [root@openshift ~]#wget https://repo.continuum.io/archive/Anaconda3-5.0.1-Linux-x86_64.sh [root@openshift ~]# yum install bzip2 [

django2.0 路由规则

Django2.0中URL的路由机制 路由是关联url及其处理函数关系的过程.Django的url路由配置在settings.py文件中ROOT_URLCONF变量指定全局路由文件名称. Django的路由都写在urls.py文件中的urlpatterns列表中,由path()或re_path()作为元素组成. Django的URL路由流程: 1 Django查找全局urlpatterns变量(urls.py) 2 按照先后顺序,对URL逐一匹配urlpatterns每个元素 3 找到第一个匹配