返回顶部

[Django] Django中url与path及re_path区别

[复制链接]
awagink 显示全部楼层 发表于 2021-3-9 15:25:07 |阅读模式 打印 上一主题 下一主题
初学者一般不能分清两者的区别,所这简单介绍下两者.首先,url是Django 1.x中的写法,p在Django2.1中,开始舍弃django1.x中的url写法。在django2.x中,描写url配置的有两个函数path和re_path.re_path()函数可以看做是django 1.x中得url函数,即可以在路径中使用正则.

一.path和url的区别:
django.urls path
django.conf.urls url
path与url是两个不同的模块,效果都是响应返回页面, path调用的是python第三方模块或框架,而url则是自定义的模块,如Views下的def函数对应你url中的参数值.

例如:

  1.     url(r'^login',views.login),
  2.     def login(request):
  3.         return render(request,'login.html')
复制代码

1、url
在settings.py文件中有一个ROOT_URLCONF设置,设置的是在访问网址时通过哪一个url文件去匹配所请求的网址

url参数
url或者re_path要复杂一些 (r’^blog/(?P[0-9]{4})/′)首先需要开始符和结尾符 ') 首先需要开始符^和结尾符 ′)首先需要开始符和结尾符,参数匹配一个 ()就是一个匹配参数,
(?P<匹配的字段名>正则表达式)

进行匹配是不包括get或者post请求方式的参数及域名比如www.qq.com/blog?num=1并不会匹配?后边的字符

可以给request参数设置一个默认值,最常见的分页url,比如

  1.     urlpatterns=[
  2.           url(r'^page/
  3.    
  4. [code]    #views
  5.    
  6.     def page(request,num='1'):
  7.          pass
复制代码

自定义错误页面关键字handler400=blog.views.page_no_find

  1.     #urls.py
  2.     …
  3.     handler400=blog.views.page_no_find
复制代码


2、path
参数的使用方法path(‘blog/str:string/’) 简单了很多,就是尖括号,前边是str代表参数的类型,后面代表参数的名称

path参数类型
捕获url中的参数需要用到尖括号<> 指定尖括号中的值类型比如int:astr:link这个转换器还有许多类型比如:

int 匹配0和正整数
str 匹配任何空字符串但不包括/
slug 可理解为注释 匹配任何ascii码包括连接线和下划线
uuid 匹配一个uuid对象(该对象必须包括破折号—,所有字母必须小写)
path 匹配所有的字符串 包括/(意思就是path前边和后边的所有)

3.re_path
如果遇上路径和转换器语法都不足以定义的URL模式,那么就需要使用正则表达式,这时候就需要使用re_path(),而非path()。

举例:传递 数字结尾的参数

  1.     re_path(r'(\d+)/


  2. [b]二、python3中使用django2,常见设置path问题[/b]
  3. 1.Django2中使用
  4. 在python3中使用django2的时候,在设置urls的时候,会遇到一些坑。这里做一下记录。
  5. 系统的urls.py里,在1.X的时候,都是采用的url方式。如下

  6.     [code]url(r'^', include("test1.urls")),
复制代码

在2.0中,它推荐使用的是path模块,所以这里就改写一下。引包

  1.     from django.urls import path
  2.    
  3.     path('', include("test1.urls")),
复制代码

注意:

如果要使用正则,则要引入re_path,from django.urls import path, re_path
这里面的正则写法,有点意思,一定要使用()把正则包起来,然后用?P正式表达式 这种形式来表式

2.APP中使用path
1.x里面的写法是

   
  1. url(r’^page=(\d+)&key=(\w+)$’, views.detail, name=”detail”),
复制代码

现在的写法

   
  1. re_path('page=(?P<page>\d+)&key=(?P<key>\w+)', views.detail, name="detail"),
复制代码

这样一对比就能明白了吧,使用的链接是http://127.0.0.1:8000/page=12&key=abc

3.系统的urls.py里的namespace的问题
1.x中写法

  
  1. url(r'^', include("test1.urls", namespace='test1')),
复制代码

可是在2.0中你这么写,会报错,说什么app_name的,这个自己可以看一下,怎么解决呢,其实很简单,只要在自己项目urls.py中加上这句就行了.如果不加的话可能报错,

   
  1. app_name = 'test1'(你的APP名)
复制代码

注:

使用url也是可以的,为了简便起见,尽量使用符合版本的字段,另外在写路径时应该严格按照语法,比如'^' 和/$就不能缺,不能前面写url,括号里面确按照path的写法,这样很容易出错,到了关键时刻,很难定位问题点,很浪费时间.

您需要登录后才可以回帖 登录 | 注册

本版积分规则

纳速健身网成立于2006年8月,是国内优秀健身运动网站,现拥浏览人数超30万。网站是集养生、武术、太极拳和健身气功等多种健身项目于一体的多功能交流平台。平台提供大量优质的教学视频、伴奏音乐(太极拳晨练音乐,广场舞音乐,健身气功音乐)、图文教程、运动科普和经验分享,为健身爱好者提供完善的运动指导平台。
  • 纳速QQ群乙:151815303
  • 纳速QQ群丙:79104490
  • 微信交流群:微信好友搜索【nasuwang】加小纳微信进群交流健身知识,备注【纳速】
  •                     或者扫描页面底部右侧二维码添加小纳微信>>>
  • 微信公众号

  • 微信群客服交流

  • Copyright © 2006-2021, 纳速健身网. | | 辽ICP备13002388号-1 辽公安网备21050202000005号公安网备号 纳速武术-乙 QQ