url()函数看起来的格式象: url(r^/account/$', views.index, name=index) ,它可以接收四个参数,分别是两个必选参数: regex 、 view 和两个可选参数: kwargs 、 name ,接下来详细介绍这四个参数。

regex

regex代表一个正则表达式,凡是与regex匹配的URL请求都会执行到url()函数中对应的第二个参数 view 代表的视图函数中。需要注意的是:正则表达式不会匹配URL中的域名和查询参数,如:http://www.foofish.net/article/?page=3, Django只找 article/ 。正则表达式在URLconf模块加载时就编译好了,所以在匹配的时候速度是很快的。

view

Django匹配正则表达式成功后,就会找到相应的视图函数,Django始终用HttpRequest对象作为第一个参数传递给视图函数,此外使用regex参数中携带的参数作为可选参数传递给视图函数。如: url(r'^(?P<article_id>\d+)/$', views.detail, name='detail') ,,括号对 (?P<article_id>\d+) 里面的参数将作为第二个参数传递给视图函数 detail(request, article_id) ,这里参数的名字必须一模一样。因为你在url函数中显示的指定了该参数的名字,当然你也可以不显示的指定,如: url(r'^(\d+)/$', views.detail, name='detail') ,这样在视图函数里,第二个参数的名称就随便命名了。它根据位置参数的位置来匹配。

name

讲name之前,先说说Django template的内建标签url, {% url path.to.some_view%} 可以返回视图函数对应的URL(相对域名的绝对路径),比如 url(r^/account/$', views.index, name=index) ,使用 {% url view.index %} 将返回 /accout/ ,这样做可以提高模版的灵活性,如果是使用硬编码的方式,模版难以维护。

使用标签url的时候可能会遇到一个问题就是:对于:

urlpatterns = patterns('',
url(r'^archive/(\d{4})/$', archive, name="full-archive"),
url(r'^archive-summary/(\d{4})/$', archive, {'summary': True}, "arch-summary"),
)
同一个视图函数有多个urlconf,此时模版系统想通过视图名 archive 获取URL时,就不知所措了,name参数就是用来解决此问题的。name用来唯一区一个视图对应多个urlconf的场景。通过name来反向获取URL。

如:

urlpatterns = patterns('',
url(r'^archive/(\d{4})/$', archive, name="full-archive"),
url(r'^archive-summary/(\d{4})/$', archive, {'summary': True}, "arch-summary"),
)
在模版中可以使用:

{% url arch-summary 1945 %}
{% url full-archive 2007 %}
kwargs

kwargs就是一个字典类型的参数,它的使用方式如:

url(r'^archive-summary/(\d{4})/$', archive, {'summary': True}, "arch-summary"),
这里的kwargs 就是 {'summary': True}

视图函数中就是这样使用:

def archive(request, archive_id, summary):
注意:

如果在url.py中有 url(r'^comment/(\d{1,9})/delete/$','delete_comment'), 的配置,如果不存在 delete_comment 这样一个函数视图,如果在模版中使用了 {% url path.to.some_view %} 这个标签,那么抛出 ViewDoesNotExit错误。仔细想想很有道理,如果视图不存在,即使匹配到了URL,当访问这个URL的时候,还是会抛ViewDoesNotExit的异常,这里Django只是在加载解析URLConf的时候就做了检查。
如果在根url.py文件中使用了 url(r'^people/', include('people.urls', namespace='people')) ,这里people是一个app,那么在people这个app中的url.py中 url(r'^(\d{1,9})/$','index', name='index') 必须指定了name=index才能正常使用{% url 'people:index'%},否则:

NoReverseMatch at /
Reverse for 'subjects' with arguments '()' and keyword arguments '{}' not found
当然如果你确定不是上述问题抛出的此异常,那么可以看下这两个答案:

http://stackoverflow.com/questions/9649587/reverse-for-with-arguments-and-keyword-arguments-not-found

http://stackoverflow.com/questions/14882491/django-release-1-5-url-requires-a-non-empty-first-argument-the-syntax-change

本文参考

https://docs.djangoproject.com/en/1.1/topics/http/urls/#id2

https://docs.djangoproject.com/en/1.1/ref/templates/builtins/#std:templatetag-url

Django1.8返回json字符串和接收post的json字符串内容 http://www.linuxidc.com/Linux/2015-07/120226.htm

如何使用 Docker 组件开发 Django 项目? http://www.codesec.net/Linux/2015-07/119961.htm

Ubuntu Server 12.04 安装Nginx+uWSGI+Django环境 http://www.codesec.net/Linux/2012-05/60639.htm

Django+Nginx+uWSGI 部署 http://www.codesec.net/Linux/2013-02/79862.htm

Django实战教程 http://www.codesec.net/Linux/2013-09/90277.htm

Django python mysql Linux 开发环境搭建 http://www.codesec.net/Linux/2013-09/90638.htm

Django 的详细介绍 :请点这里

Django 的下载地址 :请点这里

本文地址 : http://www.codesec.net/Linux/2015-08/121376.htm

本文开发(python)相关术语:python基础教程 python多线程 web开发工程师 软件开发工程师 软件开发流程

Django url()函数详解的更多相关文章

  1. 第五篇Django URL name 详解

    Django URL name 详解 利用Django开发网站,可以设计出非常优美的url规则,如果url的匹配规则(包含正则表达式)组织得比较好,view的结构就会比较清晰,比较容易维护. Djan ...

  2. Django URL name详解

    我们基于上一节的代码来开始这一节的内容. 上节源代码:zqxt_views(django 1.4 - django 1.10).zip [更新于 2016-09-06 00:13:23] 1. 打开 ...

  3. PHP输出缓存ob系列函数详解

    PHP输出缓存ob系列函数详解 ob,输出缓冲区,是output buffering的简称,而不是output cache.ob用对了,是能对速度有一定的帮助,但是盲目的加上ob函数,只会增加CPU额 ...

  4. loadrunner 脚本开发- web_url函数详解

    脚本开发- web_url函数详解 by:授客 QQ:1033553122   加载指定url的web页面(GET请求) C语言函数 int web_url( const char *StepName ...

  5. FFmpeg(2)-avformat_open_input()函数详解并示例打开mp4文件

    一. 解封装 pts 是显示的时间 dts是解码的时间, 这个时间是用来做同步. av_register_all(), 注册所有的格式.包括解封装格式和加封装格式. avformat_network_ ...

  6. python3 内置函数详解

    内置函数详解 abs(x) 返回数字的绝对值,参数可以是整数或浮点数,如果参数是复数,则返回其大小. # 如果参数是复数,则返回其大小. >>> abs(-25) 25 >&g ...

  7. 018:include函数详解

    include函数详解(了解——虽然用的很少): include函数的用法,目前有三种使用方式: 1.include(module,namespace=None): module:子url的模块字符串 ...

  8. malloc 与 free函数详解<转载>

    malloc和free函数详解   本文介绍malloc和free函数的内容. 在C中,对内存的管理是相当重要.下面开始介绍这两个函数: 一.malloc()和free()的基本概念以及基本用法: 1 ...

  9. NSSearchPathForDirectoriesInDomains函数详解

    NSSearchPathForDirectoriesInDomains函数详解     #import "NSString+FilePath.h" @implementation ...

随机推荐

  1. mac攻略(四) -- brew使用

    1.介绍 brew是一个mac新用户需要了解的必备命令,它是mac下的软件包管理软件,类似centos下的yum.ubuntu下的apt-get,免去了自己手动编译安装的不方便. 很多时候作为一个用户 ...

  2. HierarchyViewer for iOS 2.0 BETA Introduction

    We know HierarchyViewer is an useful tool in Android SDK. The developer and tester, who haven't the ...

  3. iOS,Xcode7 制作Framework,含资源和界面

    Xcode7 制作Framework  本文通过Demo方式介绍1)将含bundle和存代码编写界面打包进framework:2)将storyboard +assets.xcassets打包. (一) ...

  4. [Mysql] mysql临时表corrupt

    问题描述 机房临时硬件问题, 机器掉电. 恢复后, 重启mysql进程, 结果出现core dump. 而且一直循环, 无法终止, 只能kill掉. backtrace如下. # service my ...

  5. composer安装fxp插件时候提示内存不足且没有交换空间的解决办法

    The following exception is caused by a lack of memory and not having swap Check https://getcomposer. ...

  6. 整合Spring Data JPA与Spring MVC: 分页和排序

    之前我们学习了如何使用Jpa访问关系型数据库.比较完整Spring MVC和JPA教程请见Spring Data JPA实战入门,Spring MVC实战入门. 通过Jpa大大简化了我们对数据库的开发 ...

  7. ocLazyLoad angular 按需加载

    ionic 框架 1.引用 index.html 加载 <script type="text/javascript" src="lib/oclazyload/ocL ...

  8. android通知栏Notification点击,取消,清除响应事件

    主要是检测android通知栏的三种状态的响应事件 这次在实现推送需求的时候,要用到android通知栏Notification点击后进入消息页面,因为要实现一个保存推送用户名字的功能,我在点击后处理 ...

  9. Ubuntu 16.04 更新源

    1/ 在修改source.list前,最好先备份一份 执行备份命令 sudo cp /etc/apt/sources.list /etc/apt/sources.list.old 2/ 执行命令打开s ...

  10. mongodb unclean shutdown 修复方法

    启动mongodb时,提示Unclean shutdown detected mongodb,解决方法很简单 mongod --repair --dbpath D:\MongoDB\data\db