Django的url用法

Posted feelang

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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/(\\d4)/$', 'news.views.year_archive'),
    url(r'^articles/(\\d4)/(\\d2)/$', 'news.views.month_archive'),
    url(r'^articles/(\\d4)/(\\d2)/(\\d+)/$', 'news.views.article_detail'),
)

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

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

注意点

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

利用named group来传递参数

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

urlpatterns = patterns('',
    url(r'^articles/2003/$', 'news.views.special_case_2003'),
    url(r'^articles/(?P<year>\\d4)/$', 'news.views.year_archive'),
    url(r'^articles/(?P<year>\\d4)/(?P<month>\\d2)/$', 'news.views.month_archive'),
    url(r'^articles/(?P<year>\\d4)/(?P<month>\\d2)/(?P<day>\\d2)/$', '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/(\\d4)/$', 'year_archive'),
    url(r'^articles/(\\d4)/(\\d2)/$', 'month_archive'),
    url(r'^articles/(\\d4)/(\\d2)/(\\d+)/$', 'article_detail'),
)

指定多个view前缀

urlpatterns = patterns('myapp.views',
    url(r'^$', 'app_index'),
    url(r'^(?P<year>\\d4)/(?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>\\d4)/$', '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用法的主要内容,如果未能解决你的问题,请参考以下文章

为啥在 URL 的末尾需要一个斜杠?

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

Django基础(10): URL重定向的HttpResponseDirect, redirect和reverse的用法详解

第二章--django--URL和视图函数

django 处理静态文件

Django day004