时间:2021-05-23
初学者一般不能分清两者的区别,所这简单介绍下两者.首先,url是Django 1.x中的写法,p在Django2.1中,开始舍弃django1.x中的url写法。
在django2.x中,描写url配置的有两个函数path和re_path.re_path()函数可以看做是django 1.x中得url函数,即可以在路径中使用正则.
path与url是两个不同的模块,效果都是响应返回页面, path调用的是python第三方模块或框架,而url则是自定义的模块,如Views下的def函数对应你url中的参数值.
例如:
url(r'^login',views.login), def login(request): return render(request,'login.html')在settings.py文件中有一个ROOT_URLCONF设置,设置的是在访问网址时通过哪一个url文件去匹配所请求的网址
url参数
url或者re_path要复杂一些 (r'^blog/(?P[0-9]{4})/′)首先需要开始符和结尾符 ') 首先需要开始符^和结尾符 ′)首先需要开始符和结尾符,参数匹配一个 ()就是一个匹配参数,
(?P<匹配的字段名>正则表达式)
进行匹配是不包括get或者post请求方式的参数及域名比如/blog?num=1并不会匹配?后边的字符
可以给request参数设置一个默认值,最常见的分页url,比如
urlpatterns=[ url(r'^page/$',views.page), url(r'^page(?P<num>[0-9]+)$',views.page) ] #views def page(request,num='1'): pass自定义错误页面关键字handler400=blog.views.page_no_find
#urls.py … handler400=blog.views.page_no_find参数的使用方法path(‘blog/str:string/') 简单了很多,就是尖括号,前边是str代表参数的类型,后面代表参数的名称
path参数类型
捕获url中的参数需要用到尖括号<> 指定尖括号中的值类型比如int:astr:link这个转换器还有许多类型比如:
int 匹配0和正整数
str 匹配任何空字符串但不包括/
slug 可理解为注释 匹配任何ascii码包括连接线和下划线
uuid 匹配一个uuid对象(该对象必须包括破折号—,所有字母必须小写)
path 匹配所有的字符串 包括/(意思就是path前边和后边的所有)
如果遇上路径和转换器语法都不足以定义的URL模式,那么就需要使用正则表达式,这时候就需要使用re_path(),而非path()。
举例:传递 数字结尾的参数
re_path(r'(\d+)/$',views.peopleList,name='peopleList'),在python3中使用django2的时候,在设置urls的时候,会遇到一些坑。这里做一下记录。
系统的urls.py里,在1.X的时候,都是采用的url方式。如下
url(r'^', include("test1.urls")),在2.0中,它推荐使用的是path模块,所以这里就改写一下。引包
from django.urls import path path('', include("test1.urls")),注意:
如果要使用正则,则要引入re_path,from django.urls import path, re_path
这里面的正则写法,有点意思,一定要使用()把正则包起来,然后用?P正式表达式 这种形式来表式
1.x里面的写法是
url(r'^page=(\d+)&key=(\w+)$', views.detail, name=”detail”),现在的写法
re_path('page=(?P<page>\d+)&key=(?P<key>\w+)', views.detail, name="detail"),这样一对比就能明白了吧,使用的链接是http://127.0.0.1:8000/page=12&key=abc
1.x中写法
url(r'^', include("test1.urls", namespace='test1')),可是在2.0中你这么写,会报错,说什么app_name的,这个自己可以看一下,怎么解决呢,其实很简单,只要在自己项目urls.py中加上这句就行了.如果不加的话可能报错,
app_name = 'test1'(你的APP名)注:
使用url也是可以的,为了简便起见,尽量使用符合版本的字段,另外在写路径时应该严格按照语法,比如'^' 和/$就不能缺,不能前面写url,括号里面确按照path的写法,这样很容易出错,到了关键时刻,很难定位问题点,很浪费时间.
以上为个人经验,希望能给大家一个参考,也希望大家多多支持。如有错误或未考虑完全的地方,望不吝赐教。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
第一种分页PageNumberPagination基本使用(1)urls.pyurlpatterns=[re_path('(?P[v1|v2]+)/pa
代码示例复制代码代码如下:set_include_path(USVN_LIB_DIR.PATH_SEPARATOR.get_include_path());re
获取某目录下所有子文件和子目录functiongetDirContent($path){if(!is_dir($path)){returnfalse;}//re
思路:上面是一个典型的HTML中的图片,在django中,src对应的path会经过url进行过滤处理,所以可以通过写view过滤器的方式来实现图片压缩,代码如
方法说明:输出规范格式的path字符串。语法:复制代码代码如下:path.normalize(p)由于该方法属于path模块,使用前需要引入path模块(var