Django的url用法

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

最简单的形式


from django.conf.urls import patterns, url
urlpatterns = patterns(‘‘,
    url(r‘^articles/2003/$‘, ‘news.views.special_case_2003‘),
    url(r‘^articles/(\d{4})/$‘, ‘news.views.year_archive‘),
    url(r‘^articles/(\d{4})/(\d{2})/$‘, ‘news.views.month_archive‘),
    url(r‘^articles/(\d{4})/(\d{2})/(\d+)/$‘, ‘news.views.article_detail‘),
)

其中,正则表达式中组匹配出来的结果可以作为positional parameters传递给view.

如果url是www.yourdomain/articles/2005/,则会匹配第二条规则,执行news.views.year_archive(‘2005‘).

注意点

  • 域名部分会被过滤掉
  • articles的前面不需要添加/,因为前序url的末尾一定会有/
  • 任何组匹配的变量,都会议字符串的形式传递给view, 虽然通过(\d{4})匹配出了2005,但2005任然会被当做字符串传递给year_archive

利用named group来传递参数

可以通过以下形式为特定的组指定一个名称.

urlpatterns = patterns(‘‘,
    url(r‘^articles/2003/$‘, ‘news.views.special_case_2003‘),
    url(r‘^articles/(?P<year>\d{4})/$‘, ‘news.views.year_archive‘),
    url(r‘^articles/(?P<year>\d{4})/(?P<month>\d{2})/$‘, ‘news.views.month_archive‘),
    url(r‘^articles/(?P<year>\d{4})/(?P<month>\d{2})/(?P<day>\d{2})/$‘, ‘news.views.article_detail‘),
)

这样的话,组的匹配结果会通过keyword parameters的形式传递给view.例如year_archive(year=‘2005‘)

利用named group可以为view指定一个默认参数来匹配多条规则。

# URLconf
from django.conf.urls import patterns, url

urlpatterns = patterns(‘‘,
    url(r‘^blog/$‘, ‘blog.views.page‘),
    url(r‘^blog/page(?P<num>\d+)/$‘, ‘blog.views.page‘),
)

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

指定view前缀(提取公因式)

patterns函数的第一个参数即是view的前缀

from django.conf.urls import patterns, url

urlpatterns = patterns(‘news.views‘,
    url(r‘^articles/(\d{4})/$‘, ‘year_archive‘),
    url(r‘^articles/(\d{4})/(\d{2})/$‘, ‘month_archive‘),
    url(r‘^articles/(\d{4})/(\d{2})/(\d+)/$‘, ‘article_detail‘),
)

指定多个view前缀

urlpatterns = patterns(‘myapp.views‘,
    url(r‘^$‘, ‘app_index‘),
    url(r‘^(?P<year>\d{4})/(?P<month>[a-z]{3})/$‘,‘month_display‘),
)
urlpatterns += patterns(‘weblog.views‘,
    url(r‘^tag/(?P<tag>\w+)/$‘, ‘tag‘),
)

include其它匹配模块

from django.conf.urls import include, patterns, url

urlpatterns = patterns(‘‘,
    # ... snip ...
    url(r‘^comments/‘, include(‘django.contrib.comments.urls‘)),
    url(r‘^community/‘, include(‘django_website.aggregator.urls‘)),
    url(r‘^contact/‘, include(‘django_website.contact.urls‘)),
    # ... snip ...
)

当然也可以直接include其它patterns

from django.conf.urls import include, patterns, url

extra_patterns = patterns(‘‘,
    url(r‘^reports/(?P<id>\d+)/$‘, ‘credit.views.report‘),
    url(r‘^charge/$‘, ‘credit.views.charge‘),
)

urlpatterns = patterns(‘‘,
    url(r‘^$‘, ‘apps.main.views.homepage‘),
    url(r‘^help/‘, include(‘apps.help.urls‘)),
    url(r‘^credit/‘, include(extra_patterns)),
)

为view函数传递额外参数

from django.conf.urls import patterns, url

urlpatterns = patterns(‘blog.views‘,
    url(r‘^blog/(?P<year>\d{4})/$‘, ‘year_archive‘, {‘foo‘: ‘bar‘}),
)

直接使用view函数

from django.conf.urls import patterns, url
from mysite.views import archive, about, contact

urlpatterns = patterns(‘‘,
    url(r‘^archive/$‘, archive),
    url(r‘^about/$‘, about),
    url(r‘^contact/$‘, contact),
)

需要继续研究:Reverse resolution of URLs

参考文献:URL dispatcher

Django的url用法

时间: 2024-11-07 19:41:54

Django的url用法的相关文章

Django中url的逆向解析 -&gt; Reverse resolution of URLs

之前的一篇文章中介绍了url的基本用法[Django的url用法] 解析的过程可以概括为URL request -> view calling 同时,django又提供了另一种解析方式 - Reverse resolution of URLs 它的解析过程为 view calling -> URL request 因为Django奉行的是DRY原则,所以使用这种方式,就无需对url地址进行硬编码.在原本需要硬编码url的地方,直接可以使用url的名字,然后逆向解析出url地址. Django提

Django之URL路由系统

一 URL配置 Django 1.11版本 URLConf官方文档 URL配置(URLconf)就像Django 所支撑网站的目录.它的本质是URL与要为该URL调用的视图函数之间的映射表.你就是以这种方式告诉Django,对于这个URL调用这段代码,对于那个URL调用那段代码. 基本格式  1 2 3 4 5 from django.conf.urls import url #循环urlpatterns,找到对应的函数执行,匹配上一个路径就找到对应的函数执行,就不再往下循环了,并给函数传一个参

Django中url使用命名空间的错误

出的错误: 1. Reverse for 'llist' with arguments '()' and keyword arguments '{}' not found. 0 pattern(s) tried: [] 2. Reverse for 'home' with arguments '(1L,)' and keyword arguments '{}' not found. 1 pattern(s) tried: [u'org/home/?P<org_id>(/d+)/$'] 出错原因

二、Python Django的URL设置

Python Django的URL设置 一.url使用方式 1.正则表达方式: url(r'^blog/index/$','blog.views.index'), 2.导入的方式: from blog.views import index ..... url(r'^blog/index/$',index), ..... 3. urlpatterns = patterns('blog.views', url(r'^blog/index/$','index'), ) 二.URL参数传递给index

《二》django之url、视图、日志功能logging

django之url 参考文档:https://yiyibooks.cn/xx/Django_1.11.6/topics/http/urls.html 在setting中ROOT_URLCONF = 'devops.urls' 配置 Django如何处理请求 匹配url,都是从第一个往下匹配,若第一个可以匹配,就不用跳到第二个url规则 from django.conf.urls import url,include from . import views app_name = 'dashboa

Django之url路由

Django之url路由 url路由介绍 url路由是关联url及其视图函数关系的过程. 作用就是使views里面处理数据的函数与请求的url建立映射关系 url路由配置 Django的url路由配置在settings.py文件中ROOT_URLCONF变量指定全局路由文件名称. 注意:默认创建项目的时候,就会配置好,如果想使用别的配置文件自行修改. Django的URL路由流程 Django查找全局urlpatterns变量(urls.py) 按照先后顺序,对URL逐一匹配urlpattern

django中url路由配置及渲染方式

今天我们学习如何配置url.如何传参.如何命名.以及渲染的方式,内容大致有以下几个方面. 创建视图函数并访问 创建app django中url规则 捕获参数 路径转换器 正则表达式 额外参数 渲染方式 创建视图并访问 项目中自带的Python文件中,并没有带有视图,因此我们自己创建一个,通常,我们把视图命名views.py. 然后在views.py中,导入头文件  from django.http import HttpResponse 然后我们在views.py中,写一些Python函数,用来

django 中url与path小记

1. 在django 2.0中增加了一些新的特性 更简单的URL路由语法 (Simplified URL routing syntax) admin应用的针对移动设备的优化改进(Mobile-friendly contrib.admin) 支持SQL开窗表达式(Window expressions) 第一个特性,主要用于动态路由定义上.在Django2.0代码实现中,主要的变化是新增了 django.urls.path 函数,它允许使用一种更加简洁.可读的路由语法.比如之前的版本的代码:在dja

Django中 @login_required用法简介

我们在网站开发过程中,经常会遇到这样的需求: 用户登陆系统才可以访问某些页面 如果用户没有登陆而直接访问就会跳转到登陆界面,而不能访问其他页面. 用户在跳转的登陆界面中完成登陆后,自动访问跳转到之前访问的地址 要实现这样的需求其实很简单: 使用django自带的装饰器 @login_required. 在相应的view方法的前面添加@login_required 并在settings.py中配置LOGIN_URL参数 修改login.html中的表单action参数 view.py设置: fro