Updated middleware.txt and url_dispatch.txt docs to reflect [1470] (support for non-named groups in URLconf regexes)
git-svn-id: http://code.djangoproject.com/svn/django/trunk@1471 bcc190cf-cafb-0310-a4f2-bffc1f526a37
This commit is contained in:
parent
cc3660c07d
commit
f1eff69a4f
|
@ -125,12 +125,14 @@ the appropriate view; it'll return that ``HttpResponse``.
|
||||||
process_view
|
process_view
|
||||||
------------
|
------------
|
||||||
|
|
||||||
Interface: ``process_view(self, request, view_func, param_dict)``
|
Interface: ``process_view(self, request, view_func, view_args, view_kwargs)``
|
||||||
|
|
||||||
``request`` is an ``HttpRequest`` object. ``view_func`` is the Python function
|
``request`` is an ``HttpRequest`` object. ``view_func`` is the Python function
|
||||||
that Django is about to use. (It's the actual function object, not the name of
|
that Django is about to use. (It's the actual function object, not the name of
|
||||||
the function as a string.) ``param_dict`` is a dictionary of keyword arguments
|
the function as a string.) ``view_args`` is a list of positional arguments that
|
||||||
that will be passed to the view -- NOT including the first argument (``request``).
|
will be passed to the view, and ``view_kwargs`` is a dictionary of keyword
|
||||||
|
arguments that will be passed to the view. Neither ``view_args`` nor
|
||||||
|
``view_kwargs`` include the first view argument (``request``).
|
||||||
|
|
||||||
``process_view()`` is called just before Django calls the view. It should
|
``process_view()`` is called just before Django calls the view. It should
|
||||||
return either ``None`` or an ``HttpResponse`` object. If it returns ``None``,
|
return either ``None`` or an ``HttpResponse`` object. If it returns ``None``,
|
||||||
|
|
|
@ -42,7 +42,7 @@ algorithm the system follows to determine which Python code to execute:
|
||||||
first one that matches the requested URL.
|
first one that matches the requested URL.
|
||||||
4. Once one of the regexes matches, Django imports and calls the given
|
4. Once one of the regexes matches, Django imports and calls the given
|
||||||
view, which is a simple Python function. The view gets passed a
|
view, which is a simple Python function. The view gets passed a
|
||||||
`request object`_ and any values captured in the regex as keyword
|
`request object`_ and any values captured in the regex as function
|
||||||
arguments.
|
arguments.
|
||||||
|
|
||||||
.. _settings file: http://www.djangoproject.com/documentation/settings/
|
.. _settings file: http://www.djangoproject.com/documentation/settings/
|
||||||
|
@ -51,15 +51,18 @@ algorithm the system follows to determine which Python code to execute:
|
||||||
Example
|
Example
|
||||||
=======
|
=======
|
||||||
|
|
||||||
|
**This syntax is new in the Django development version.** See "Named groups"
|
||||||
|
below if you're using Django 0.90.
|
||||||
|
|
||||||
Here's a sample URLconf::
|
Here's a sample URLconf::
|
||||||
|
|
||||||
from django.conf.urls.defaults import *
|
from django.conf.urls.defaults import *
|
||||||
|
|
||||||
urlpatterns = patterns('',
|
urlpatterns = patterns('',
|
||||||
(r'^articles/2003/$', 'news.views.special_case_2003'),
|
(r'^articles/2003/$', 'news.views.special_case_2003'),
|
||||||
(r'^articles/(?P<year>\d{4})/$', 'news.views.year_archive'),
|
(r'^articles/(\d{4})/$', 'news.views.year_archive'),
|
||||||
(r'^articles/(?P<year>\d{4})/(?P<month>\d{2})/$', 'news.views.month_archive'),
|
(r'^articles/(\d{4})/(\d{2})/$', 'news.views.month_archive'),
|
||||||
(r'^articles/(?P<year>\d{4})/(?P<month>\d{2})/(?P<day>\d+)/$', 'news.views.article_detail'),
|
(r'^articles/(\d{4})/(\d{2})/(\d+)/$', 'news.views.article_detail'),
|
||||||
)
|
)
|
||||||
|
|
||||||
Notes:
|
Notes:
|
||||||
|
@ -67,9 +70,7 @@ Notes:
|
||||||
* ``from django.conf.urls.defaults import *`` makes the ``patterns``
|
* ``from django.conf.urls.defaults import *`` makes the ``patterns``
|
||||||
function available.
|
function available.
|
||||||
|
|
||||||
* To capture a value from the URL, use the syntax ``(?P<name>pattern)``,
|
* To capture a value from the URL, just put parenthesis around it.
|
||||||
where ``name`` is the name for that value and ``pattern`` is some pattern
|
|
||||||
to match.
|
|
||||||
|
|
||||||
* There's no need to add a leading slash, because every URL has that. For
|
* There's no need to add a leading slash, because every URL has that. For
|
||||||
example, it's ``^articles``, not ``^/articles``.
|
example, it's ``^articles``, not ``^/articles``.
|
||||||
|
@ -82,7 +83,7 @@ Examples:
|
||||||
|
|
||||||
* A request to ``/articles/2005/03/`` would match the third entry in the
|
* A request to ``/articles/2005/03/`` would match the third entry in the
|
||||||
list. Django would call the function
|
list. Django would call the function
|
||||||
``news.views.month_archive(request, year='2005', month='03')``.
|
``news.views.month_archive(request, '2005', '03')``.
|
||||||
|
|
||||||
* ``/articles/2005/3/`` would not match any URL patterns, because the
|
* ``/articles/2005/3/`` would not match any URL patterns, because the
|
||||||
third entry in the list requires two digits for the month.
|
third entry in the list requires two digits for the month.
|
||||||
|
@ -96,11 +97,68 @@ Examples:
|
||||||
pattern requires that the URL end with a slash.
|
pattern requires that the URL end with a slash.
|
||||||
|
|
||||||
* ``/articles/2003/03/3/`` would match the final pattern. Django would call
|
* ``/articles/2003/03/3/`` would match the final pattern. Django would call
|
||||||
the function
|
the function ``news.views.article_detail(request, '2003', '03', '3')``.
|
||||||
``news.views.article_detail(request, year='2003', month='03', day='3')``.
|
|
||||||
|
|
||||||
.. _Dive Into Python's explanation: http://diveintopython.org/regular_expressions/street_addresses.html#re.matching.2.3
|
.. _Dive Into Python's explanation: http://diveintopython.org/regular_expressions/street_addresses.html#re.matching.2.3
|
||||||
|
|
||||||
|
Named groups
|
||||||
|
============
|
||||||
|
|
||||||
|
The above example used simple, *non-named* regular-expression groups (via
|
||||||
|
parenthesis) to capture bits of the URL and pass them as *positional* arguments
|
||||||
|
to a view. In more advanced usage, it's possible to use *named*
|
||||||
|
regular-expression groups to capture URL bits and pass them as *keyword*
|
||||||
|
arguments to a view.
|
||||||
|
|
||||||
|
(Note that support for non-named regex groups is a new feature in the Django
|
||||||
|
development version. Django 0.90 requires named groups.)
|
||||||
|
|
||||||
|
In Python regular expressions, the syntax for named regular-expression groups
|
||||||
|
is ``(?P<name>pattern)``, where ``name`` is the name of the group and
|
||||||
|
``pattern`` is some pattern to match.
|
||||||
|
|
||||||
|
Here's the above example URLconf, rewritten to use named groups::
|
||||||
|
|
||||||
|
urlpatterns = patterns('',
|
||||||
|
(r'^articles/2003/$', 'news.views.special_case_2003'),
|
||||||
|
(r'^articles/(?P<year>\d{4})/$', 'news.views.year_archive'),
|
||||||
|
(r'^articles/(?P<year>\d{4})/(?P<month>\d{2})/$', 'news.views.month_archive'),
|
||||||
|
(r'^articles/(?P<year>\d{4})/(?P<month>\d{2})/(?P<day>\d+)/$', 'news.views.article_detail'),
|
||||||
|
)
|
||||||
|
|
||||||
|
This accomplishes exactly the same thing as the previous example, with one
|
||||||
|
subtle difference: The captured values are passed as keyword arguments rather
|
||||||
|
than positional arguments. For example:
|
||||||
|
|
||||||
|
* A request to ``/articles/2005/03/`` would call the function
|
||||||
|
``news.views.month_archive(request, year='2005', month='03')``, instead
|
||||||
|
of ``news.views.month_archive(request, '2005', '03')``.
|
||||||
|
|
||||||
|
* A request to ``/articles/2003/03/3/`` would call the function
|
||||||
|
``news.views.article_detail(request, year='2003', month='03', day='3')``.
|
||||||
|
|
||||||
|
In practice, this means your URLconfs are slightly more explicit and less prone
|
||||||
|
to argument-order bugs -- and you can reorder the arguments in your views'
|
||||||
|
function definitions. Of course, these benefits come at the cost of brevity;
|
||||||
|
some folks find the named-group syntax ugly and too verbose.
|
||||||
|
|
||||||
|
The matching/grouping algorithm
|
||||||
|
-------------------------------
|
||||||
|
|
||||||
|
Here's the algorithm the URLconf parser follows, with respect to named groups
|
||||||
|
vs. non-named groups in a regular expression:
|
||||||
|
|
||||||
|
* If there are any named groups, it will use those as keyword arguments,
|
||||||
|
ignoring any non-named groups.
|
||||||
|
* Otherwise, it will pass all non-named groups as positional arguments.
|
||||||
|
* In both cases, it will pass any extra
|
||||||
|
|
||||||
|
If there are any named arguments, it will use those, ignoring non-named arguments.
|
||||||
|
Otherwise, it will pass all non-named arguments as positional arguments.
|
||||||
|
|
||||||
|
In both cases, it will pass any extra keyword arguments as keyword arguments.
|
||||||
|
See "Passing extra options to view functions" below.
|
||||||
|
|
||||||
What the URLconf searches against
|
What the URLconf searches against
|
||||||
=================================
|
=================================
|
||||||
|
|
||||||
|
@ -169,7 +227,7 @@ Notes on capturing text in URLs
|
||||||
|
|
||||||
Each captured argument is sent to the view as a plain Python string, regardless
|
Each captured argument is sent to the view as a plain Python string, regardless
|
||||||
of what sort of match the regular expression makes. For example, in this
|
of what sort of match the regular expression makes. For example, in this
|
||||||
URLconf::
|
URLconf line::
|
||||||
|
|
||||||
(r'^articles/(?P<year>\d{4})/$', 'news.views.year_archive'),
|
(r'^articles/(?P<year>\d{4})/$', 'news.views.year_archive'),
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue