mirror of
				https://github.com/django/django.git
				synced 2025-10-22 08:12:11 +00:00 
			
		
		
		
	Merge pull request #1129 from frog32/master
Add needed Imports to the Documentation
This commit is contained in:
		
						commit
						33c361ef9d
					
				
					 23 changed files with 211 additions and 35 deletions
				
			
		
							
								
								
									
										3
									
								
								AUTHORS
									
										
									
									
									
								
							
							
						
						
									
										3
									
								
								AUTHORS
									
										
									
									
									
								
							|  | @ -197,6 +197,7 @@ answer newbie questions, and generally made Django that much better: | ||||||
|     J. Clifford Dyer <jcd@sdf.lonestar.org> |     J. Clifford Dyer <jcd@sdf.lonestar.org> | ||||||
|     Clint Ecker |     Clint Ecker | ||||||
|     Nick Efford <nick@efford.org> |     Nick Efford <nick@efford.org> | ||||||
|  |     Marc Egli <frog32@me.com> | ||||||
|     eibaan@gmail.com |     eibaan@gmail.com | ||||||
|     David Eklund |     David Eklund | ||||||
|     Julia Elman |     Julia Elman | ||||||
|  | @ -221,6 +222,7 @@ answer newbie questions, and generally made Django that much better: | ||||||
|     Stefane Fermgier <sf@fermigier.com> |     Stefane Fermgier <sf@fermigier.com> | ||||||
|     J. Pablo Fernandez <pupeno@pupeno.com> |     J. Pablo Fernandez <pupeno@pupeno.com> | ||||||
|     Maciej Fijalkowski |     Maciej Fijalkowski | ||||||
|  |     Leandra Finger <leandra.finger@gmail.com> | ||||||
|     Juan Pedro Fisanotti <fisadev@gmail.com> |     Juan Pedro Fisanotti <fisadev@gmail.com> | ||||||
|     Ben Firshman <ben@firshman.co.uk> |     Ben Firshman <ben@firshman.co.uk> | ||||||
|     Matthew Flanagan <http://wadofstuff.blogspot.com> |     Matthew Flanagan <http://wadofstuff.blogspot.com> | ||||||
|  | @ -531,6 +533,7 @@ answer newbie questions, and generally made Django that much better: | ||||||
|     Don Spaulding <donspauldingii@gmail.com> |     Don Spaulding <donspauldingii@gmail.com> | ||||||
|     Calvin Spealman <ironfroggy@gmail.com> |     Calvin Spealman <ironfroggy@gmail.com> | ||||||
|     Dane Springmeyer |     Dane Springmeyer | ||||||
|  |     Silvan Spross <silvan.spross@gmail.com> | ||||||
|     Bjørn Stabell <bjorn@exoweb.net> |     Bjørn Stabell <bjorn@exoweb.net> | ||||||
|     Georgi Stanojevski <glisha@gmail.com> |     Georgi Stanojevski <glisha@gmail.com> | ||||||
|     starrynight <cmorgh@gmail.com> |     starrynight <cmorgh@gmail.com> | ||||||
|  |  | ||||||
|  | @ -24,6 +24,8 @@ representing your models -- so far, it's been solving two years' worth of | ||||||
| database-schema problems. Here's a quick example, which might be saved in | database-schema problems. Here's a quick example, which might be saved in | ||||||
| the file ``mysite/news/models.py``:: | the file ``mysite/news/models.py``:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models  | ||||||
|  | 
 | ||||||
|     class Reporter(models.Model): |     class Reporter(models.Model): | ||||||
|         full_name = models.CharField(max_length=70) |         full_name = models.CharField(max_length=70) | ||||||
| 
 | 
 | ||||||
|  | @ -214,6 +216,8 @@ Generally, a view retrieves data according to the parameters, loads a template | ||||||
| and renders the template with the retrieved data. Here's an example view for | and renders the template with the retrieved data. Here's an example view for | ||||||
| ``year_archive`` from above:: | ``year_archive`` from above:: | ||||||
| 
 | 
 | ||||||
|  |     from django.shortcuts import render_to_response  | ||||||
|  | 
 | ||||||
|     def year_archive(request, year): |     def year_archive(request, year): | ||||||
|         a_list = Article.objects.filter(pub_date__year=year) |         a_list = Article.objects.filter(pub_date__year=year) | ||||||
|         return render_to_response('news/year_archive.html', {'year': year, 'article_list': a_list}) |         return render_to_response('news/year_archive.html', {'year': year, 'article_list': a_list}) | ||||||
|  |  | ||||||
|  | @ -582,6 +582,8 @@ of this object. Let's fix that by editing the polls model (in the | ||||||
| ``Choice``. On Python 3, simply replace ``__unicode__`` by ``__str__`` in the | ``Choice``. On Python 3, simply replace ``__unicode__`` by ``__str__`` in the | ||||||
| following example:: | following example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Poll(models.Model): |     class Poll(models.Model): | ||||||
|         # ... |         # ... | ||||||
|         def __unicode__(self):  # Python 3: def __str__(self): |         def __unicode__(self):  # Python 3: def __str__(self): | ||||||
|  |  | ||||||
|  | @ -158,6 +158,9 @@ you want when you register the object. | ||||||
| Let's see how this works by re-ordering the fields on the edit form. Replace | Let's see how this works by re-ordering the fields on the edit form. Replace | ||||||
| the ``admin.site.register(Poll)`` line with:: | the ``admin.site.register(Poll)`` line with:: | ||||||
| 
 | 
 | ||||||
|  |     from django.contrib import admin | ||||||
|  |     from polls.models import Poll | ||||||
|  | 
 | ||||||
|     class PollAdmin(admin.ModelAdmin): |     class PollAdmin(admin.ModelAdmin): | ||||||
|         fields = ['pub_date', 'question'] |         fields = ['pub_date', 'question'] | ||||||
| 
 | 
 | ||||||
|  | @ -179,6 +182,9 @@ of fields, choosing an intuitive order is an important usability detail. | ||||||
| And speaking of forms with dozens of fields, you might want to split the form | And speaking of forms with dozens of fields, you might want to split the form | ||||||
| up into fieldsets:: | up into fieldsets:: | ||||||
| 
 | 
 | ||||||
|  |     from django.contrib import admin | ||||||
|  |     from polls.models import Poll | ||||||
|  | 
 | ||||||
|     class PollAdmin(admin.ModelAdmin): |     class PollAdmin(admin.ModelAdmin): | ||||||
|         fieldsets = [ |         fieldsets = [ | ||||||
|             (None,               {'fields': ['question']}), |             (None,               {'fields': ['question']}), | ||||||
|  | @ -198,6 +204,9 @@ You can assign arbitrary HTML classes to each fieldset. Django provides a | ||||||
| This is useful when you have a long form that contains a number of fields that | This is useful when you have a long form that contains a number of fields that | ||||||
| aren't commonly used:: | aren't commonly used:: | ||||||
| 
 | 
 | ||||||
|  |         from django.contrib import admin | ||||||
|  |         from polls.models import Poll | ||||||
|  | 
 | ||||||
|         class PollAdmin(admin.ModelAdmin): |         class PollAdmin(admin.ModelAdmin): | ||||||
|             fieldsets = [ |             fieldsets = [ | ||||||
|                 (None,               {'fields': ['question']}), |                 (None,               {'fields': ['question']}), | ||||||
|  | @ -218,6 +227,7 @@ Yet. | ||||||
| There are two ways to solve this problem. The first is to register ``Choice`` | There are two ways to solve this problem. The first is to register ``Choice`` | ||||||
| with the admin just as we did with ``Poll``. That's easy:: | with the admin just as we did with ``Poll``. That's easy:: | ||||||
| 
 | 
 | ||||||
|  |     from django.contrib import admin | ||||||
|     from polls.models import Choice |     from polls.models import Choice | ||||||
| 
 | 
 | ||||||
|     admin.site.register(Choice) |     admin.site.register(Choice) | ||||||
|  | @ -342,6 +352,12 @@ representation of the output. | ||||||
| You can improve that by giving that method (in :file:`polls/models.py`) a few | You can improve that by giving that method (in :file:`polls/models.py`) a few | ||||||
| attributes, as follows:: | attributes, as follows:: | ||||||
| 
 | 
 | ||||||
|  |     import datetime | ||||||
|  |     from django.utils import timezone | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|  |     from polls.models import Poll | ||||||
|  | 
 | ||||||
|     class Poll(models.Model): |     class Poll(models.Model): | ||||||
|         # ... |         # ... | ||||||
|         def was_published_recently(self): |         def was_published_recently(self): | ||||||
|  |  | ||||||
|  | @ -393,6 +393,9 @@ Now, let's tackle the poll detail view -- the page that displays the question | ||||||
| for a given poll. Here's the view:: | for a given poll. Here's the view:: | ||||||
| 
 | 
 | ||||||
|     from django.http import Http404 |     from django.http import Http404 | ||||||
|  |     from django.shortcuts import render | ||||||
|  | 
 | ||||||
|  |     from polls.models import Poll | ||||||
|     # ... |     # ... | ||||||
|     def detail(request, poll_id): |     def detail(request, poll_id): | ||||||
|         try: |         try: | ||||||
|  | @ -420,6 +423,8 @@ and raise :exc:`~django.http.Http404` if the object doesn't exist. Django | ||||||
| provides a shortcut. Here's the ``detail()`` view, rewritten:: | provides a shortcut. Here's the ``detail()`` view, rewritten:: | ||||||
| 
 | 
 | ||||||
|     from django.shortcuts import render, get_object_or_404 |     from django.shortcuts import render, get_object_or_404 | ||||||
|  | 
 | ||||||
|  |     from polls.models import Poll | ||||||
|     # ... |     # ... | ||||||
|     def detail(request, poll_id): |     def detail(request, poll_id): | ||||||
|         poll = get_object_or_404(Poll, pk=poll_id) |         poll = get_object_or_404(Poll, pk=poll_id) | ||||||
|  |  | ||||||
|  | @ -136,6 +136,8 @@ object. For more on :class:`~django.http.HttpRequest` objects, see the | ||||||
| After somebody votes in a poll, the ``vote()`` view redirects to the results | After somebody votes in a poll, the ``vote()`` view redirects to the results | ||||||
| page for the poll. Let's write that view:: | page for the poll. Let's write that view:: | ||||||
| 
 | 
 | ||||||
|  |     from django.shortcuts import get_object_or_404, render | ||||||
|  | 
 | ||||||
|     def results(request, poll_id): |     def results(request, poll_id): | ||||||
|         poll = get_object_or_404(Poll, pk=poll_id) |         poll = get_object_or_404(Poll, pk=poll_id) | ||||||
|         return render(request, 'polls/results.html', {'poll': poll}) |         return render(request, 'polls/results.html', {'poll': poll}) | ||||||
|  |  | ||||||
|  | @ -98,6 +98,8 @@ second element is the human-readable name. For example:: | ||||||
| Generally, it's best to define choices inside a model class, and to | Generally, it's best to define choices inside a model class, and to | ||||||
| define a suitably-named constant for each value:: | define a suitably-named constant for each value:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Student(models.Model): |     class Student(models.Model): | ||||||
|         FRESHMAN = 'FR' |         FRESHMAN = 'FR' | ||||||
|         SOPHOMORE = 'SO' |         SOPHOMORE = 'SO' | ||||||
|  | @ -997,12 +999,15 @@ relationship with itself -- use ``models.ForeignKey('self')``. | ||||||
| If you need to create a relationship on a model that has not yet been defined, | If you need to create a relationship on a model that has not yet been defined, | ||||||
| you can use the name of the model, rather than the model object itself:: | you can use the name of the model, rather than the model object itself:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Car(models.Model): |     class Car(models.Model): | ||||||
|         manufacturer = models.ForeignKey('Manufacturer') |         manufacturer = models.ForeignKey('Manufacturer') | ||||||
|         # ... |         # ... | ||||||
| 
 | 
 | ||||||
|     class Manufacturer(models.Model): |     class Manufacturer(models.Model): | ||||||
|         # ... |         # ... | ||||||
|  |         pass | ||||||
| 
 | 
 | ||||||
| To refer to models defined in another application, you can explicitly specify | To refer to models defined in another application, you can explicitly specify | ||||||
| a model with the full application label. For example, if the ``Manufacturer`` | a model with the full application label. For example, if the ``Manufacturer`` | ||||||
|  | @ -1135,6 +1140,9 @@ The possible values for :attr:`~ForeignKey.on_delete` are found in | ||||||
|     necessary to avoid executing queries at the time your models.py is |     necessary to avoid executing queries at the time your models.py is | ||||||
|     imported:: |     imported:: | ||||||
| 
 | 
 | ||||||
|  |         from django.db import models | ||||||
|  |         from django.contrib.auth.models import User | ||||||
|  | 
 | ||||||
|         def get_sentinel_user(): |         def get_sentinel_user(): | ||||||
|             return User.objects.get_or_create(username='deleted')[0] |             return User.objects.get_or_create(username='deleted')[0] | ||||||
| 
 | 
 | ||||||
|  | @ -1207,6 +1215,8 @@ that control how the relationship functions. | ||||||
|     Only used in the definition of ManyToManyFields on self. Consider the |     Only used in the definition of ManyToManyFields on self. Consider the | ||||||
|     following model:: |     following model:: | ||||||
| 
 | 
 | ||||||
|  |         from django.db import models | ||||||
|  | 
 | ||||||
|         class Person(models.Model): |         class Person(models.Model): | ||||||
|             friends = models.ManyToManyField("self") |             friends = models.ManyToManyField("self") | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -34,6 +34,8 @@ that, you need to :meth:`~Model.save()`. | ||||||
| 
 | 
 | ||||||
|     1. Add a classmethod on the model class:: |     1. Add a classmethod on the model class:: | ||||||
| 
 | 
 | ||||||
|  |         from django.db import models | ||||||
|  | 
 | ||||||
|         class Book(models.Model): |         class Book(models.Model): | ||||||
|             title = models.CharField(max_length=100) |             title = models.CharField(max_length=100) | ||||||
| 
 | 
 | ||||||
|  | @ -105,6 +107,7 @@ individually. | ||||||
| You'll need to call ``full_clean`` manually when you want to run one-step model | You'll need to call ``full_clean`` manually when you want to run one-step model | ||||||
| validation for your own manually created models. For example:: | validation for your own manually created models. For example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.core.exceptions import ValidationError | ||||||
|     try: |     try: | ||||||
|         article.full_clean() |         article.full_clean() | ||||||
|     except ValidationError as e: |     except ValidationError as e: | ||||||
|  | @ -132,6 +135,7 @@ automatically provide a value for a field, or to do validation that requires | ||||||
| access to more than a single field:: | access to more than a single field:: | ||||||
| 
 | 
 | ||||||
|     def clean(self): |     def clean(self): | ||||||
|  |         import datetime | ||||||
|         from django.core.exceptions import ValidationError |         from django.core.exceptions import ValidationError | ||||||
|         # Don't allow draft entries to have a pub_date. |         # Don't allow draft entries to have a pub_date. | ||||||
|         if self.status == 'draft' and self.pub_date is not None: |         if self.status == 'draft' and self.pub_date is not None: | ||||||
|  | @ -434,6 +438,8 @@ representation of the model from the ``__unicode__()`` method. | ||||||
| 
 | 
 | ||||||
| For example:: | For example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Person(models.Model): |     class Person(models.Model): | ||||||
|         first_name = models.CharField(max_length=50) |         first_name = models.CharField(max_length=50) | ||||||
|         last_name = models.CharField(max_length=50) |         last_name = models.CharField(max_length=50) | ||||||
|  | @ -460,6 +466,9 @@ Thus, you should return a nice, human-readable string for the object's | ||||||
| The previous :meth:`~Model.__unicode__()` example could be similarly written | The previous :meth:`~Model.__unicode__()` example could be similarly written | ||||||
| using ``__str__()`` like this:: | using ``__str__()`` like this:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  |     from django.utils.encoding import force_bytes | ||||||
|  | 
 | ||||||
|     class Person(models.Model): |     class Person(models.Model): | ||||||
|         first_name = models.CharField(max_length=50) |         first_name = models.CharField(max_length=50) | ||||||
|         last_name = models.CharField(max_length=50) |         last_name = models.CharField(max_length=50) | ||||||
|  | @ -490,6 +499,7 @@ function is usually the best approach.) | ||||||
| For example:: | For example:: | ||||||
| 
 | 
 | ||||||
|     def get_absolute_url(self): |     def get_absolute_url(self): | ||||||
|  |         from django.core.urlresolvers import reverse | ||||||
|         return reverse('people.views.details', args=[str(self.id)]) |         return reverse('people.views.details', args=[str(self.id)]) | ||||||
| 
 | 
 | ||||||
| One place Django uses ``get_absolute_url()`` is in the admin app. If an object | One place Django uses ``get_absolute_url()`` is in the admin app. If an object | ||||||
|  |  | ||||||
|  | @ -145,6 +145,12 @@ Django quotes column and table names behind the scenes. | ||||||
|     and a question has more than one answer, and the order of answers matters, you'd |     and a question has more than one answer, and the order of answers matters, you'd | ||||||
|     do this:: |     do this:: | ||||||
| 
 | 
 | ||||||
|  |         from django.db import models | ||||||
|  | 
 | ||||||
|  |         class Question(models.Model): | ||||||
|  |             text = models.TextField() | ||||||
|  |             # ... | ||||||
|  | 
 | ||||||
|         class Answer(models.Model): |         class Answer(models.Model): | ||||||
|             question = models.ForeignKey(Question) |             question = models.ForeignKey(Question) | ||||||
|             # ... |             # ... | ||||||
|  |  | ||||||
|  | @ -232,6 +232,7 @@ the model field that is being aggregated. | ||||||
| For example, if you were manipulating a list of blogs, you may want | For example, if you were manipulating a list of blogs, you may want | ||||||
| to determine how many entries have been made in each blog:: | to determine how many entries have been made in each blog:: | ||||||
| 
 | 
 | ||||||
|  |     >>> from django.db.models import Count | ||||||
|     >>> q = Blog.objects.annotate(Count('entry')) |     >>> q = Blog.objects.annotate(Count('entry')) | ||||||
|     # The name of the first blog |     # The name of the first blog | ||||||
|     >>> q[0].name |     >>> q[0].name | ||||||
|  | @ -699,6 +700,8 @@ And here's ``select_related`` lookup:: | ||||||
| ``select_related()`` follows foreign keys as far as possible. If you have the | ``select_related()`` follows foreign keys as far as possible. If you have the | ||||||
| following models:: | following models:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class City(models.Model): |     class City(models.Model): | ||||||
|         # ... |         # ... | ||||||
|         pass |         pass | ||||||
|  | @ -814,6 +817,8 @@ that are supported by ``select_related``. It also supports prefetching of | ||||||
| 
 | 
 | ||||||
| For example, suppose you have these models:: | For example, suppose you have these models:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Topping(models.Model): |     class Topping(models.Model): | ||||||
|         name = models.CharField(max_length=30) |         name = models.CharField(max_length=30) | ||||||
| 
 | 
 | ||||||
|  | @ -1565,6 +1570,7 @@ aggregated. | ||||||
| For example, when you are working with blog entries, you may want to know the | For example, when you are working with blog entries, you may want to know the | ||||||
| number of authors that have contributed blog entries:: | number of authors that have contributed blog entries:: | ||||||
| 
 | 
 | ||||||
|  |     >>> from django.db.models import Count | ||||||
|     >>> q = Blog.objects.aggregate(Count('entry')) |     >>> q = Blog.objects.aggregate(Count('entry')) | ||||||
|     {'entry__count': 16} |     {'entry__count': 16} | ||||||
| 
 | 
 | ||||||
|  | @ -2042,6 +2048,7 @@ Range test (inclusive). | ||||||
| 
 | 
 | ||||||
| Example:: | Example:: | ||||||
| 
 | 
 | ||||||
|  |     import datetime | ||||||
|     start_date = datetime.date(2005, 1, 1) |     start_date = datetime.date(2005, 1, 1) | ||||||
|     end_date = datetime.date(2005, 3, 31) |     end_date = datetime.date(2005, 3, 31) | ||||||
|     Entry.objects.filter(pub_date__range=(start_date, end_date)) |     Entry.objects.filter(pub_date__range=(start_date, end_date)) | ||||||
|  |  | ||||||
|  | @ -12,8 +12,11 @@ Related objects reference | ||||||
|     * The "other side" of a :class:`~django.db.models.ForeignKey` relation. |     * The "other side" of a :class:`~django.db.models.ForeignKey` relation. | ||||||
|       That is:: |       That is:: | ||||||
| 
 | 
 | ||||||
|  |             from django.db import models | ||||||
|  | 
 | ||||||
|             class Reporter(models.Model): |             class Reporter(models.Model): | ||||||
|                 ... |                 # ... | ||||||
|  |                 pass | ||||||
| 
 | 
 | ||||||
|             class Article(models.Model): |             class Article(models.Model): | ||||||
|                 reporter = models.ForeignKey(Reporter) |                 reporter = models.ForeignKey(Reporter) | ||||||
|  | @ -24,7 +27,8 @@ Related objects reference | ||||||
|     * Both sides of a :class:`~django.db.models.ManyToManyField` relation:: |     * Both sides of a :class:`~django.db.models.ManyToManyField` relation:: | ||||||
| 
 | 
 | ||||||
|             class Topping(models.Model): |             class Topping(models.Model): | ||||||
|                 ... |                 # ... | ||||||
|  |                 pass | ||||||
| 
 | 
 | ||||||
|             class Pizza(models.Model): |             class Pizza(models.Model): | ||||||
|                 toppings = models.ManyToManyField(Topping) |                 toppings = models.ManyToManyField(Topping) | ||||||
|  |  | ||||||
|  | @ -215,6 +215,7 @@ re-rendered, you can re-evaluate the rendered content, and assign | ||||||
| the content of the response manually:: | the content of the response manually:: | ||||||
| 
 | 
 | ||||||
|     # Set up a rendered TemplateResponse |     # Set up a rendered TemplateResponse | ||||||
|  |     >>> from django.template.response import TemplateResponse | ||||||
|     >>> t = TemplateResponse(request, 'original.html', {}) |     >>> t = TemplateResponse(request, 'original.html', {}) | ||||||
|     >>> t.render() |     >>> t.render() | ||||||
|     >>> print(t.content) |     >>> print(t.content) | ||||||
|  | @ -256,6 +257,8 @@ To define a post-render callback, just define a function that takes | ||||||
| a single argument -- response -- and register that function with | a single argument -- response -- and register that function with | ||||||
| the template response:: | the template response:: | ||||||
| 
 | 
 | ||||||
|  |     from django.template.response import TemplateResponse | ||||||
|  | 
 | ||||||
|     def my_render_callback(response): |     def my_render_callback(response): | ||||||
|         # Do content-sensitive processing |         # Do content-sensitive processing | ||||||
|         do_post_processing() |         do_post_processing() | ||||||
|  |  | ||||||
|  | @ -248,7 +248,7 @@ specify the objects that the view will operate upon -- you can also | ||||||
| specify the list of objects using the ``queryset`` argument:: | specify the list of objects using the ``queryset`` argument:: | ||||||
| 
 | 
 | ||||||
|     from django.views.generic import DetailView |     from django.views.generic import DetailView | ||||||
|     from books.models import Publisher, Book |     from books.models import Publisher | ||||||
| 
 | 
 | ||||||
|     class PublisherDetail(DetailView): |     class PublisherDetail(DetailView): | ||||||
| 
 | 
 | ||||||
|  | @ -326,6 +326,7 @@ various useful things are stored on ``self``; as well as the request | ||||||
| Here, we have a URLconf with a single captured group:: | Here, we have a URLconf with a single captured group:: | ||||||
| 
 | 
 | ||||||
|     # urls.py |     # urls.py | ||||||
|  |     from django.conf.urls import patterns | ||||||
|     from books.views import PublisherBookList |     from books.views import PublisherBookList | ||||||
| 
 | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|  | @ -375,6 +376,7 @@ Imagine we had a ``last_accessed`` field on our ``Author`` object that we were | ||||||
| using to keep track of the last time anybody looked at that author:: | using to keep track of the last time anybody looked at that author:: | ||||||
| 
 | 
 | ||||||
|     # models.py |     # models.py | ||||||
|  |     from django.db import models | ||||||
| 
 | 
 | ||||||
|     class Author(models.Model): |     class Author(models.Model): | ||||||
|         salutation = models.CharField(max_length=10) |         salutation = models.CharField(max_length=10) | ||||||
|  | @ -390,6 +392,7 @@ updated. | ||||||
| First, we'd need to add an author detail bit in the URLconf to point to a | First, we'd need to add an author detail bit in the URLconf to point to a | ||||||
| custom view:: | custom view:: | ||||||
| 
 | 
 | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|     from books.views import AuthorDetailView |     from books.views import AuthorDetailView | ||||||
| 
 | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|  | @ -401,7 +404,6 @@ Then we'd write our new view -- ``get_object`` is the method that retrieves the | ||||||
| object -- so we simply override it and wrap the call:: | object -- so we simply override it and wrap the call:: | ||||||
| 
 | 
 | ||||||
|     from django.views.generic import DetailView |     from django.views.generic import DetailView | ||||||
|     from django.shortcuts import get_object_or_404 |  | ||||||
|     from django.utils import timezone |     from django.utils import timezone | ||||||
|     from books.models import Author |     from books.models import Author | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -222,6 +222,7 @@ works for AJAX requests as well as 'normal' form POSTs:: | ||||||
| 
 | 
 | ||||||
|     from django.http import HttpResponse |     from django.http import HttpResponse | ||||||
|     from django.views.generic.edit import CreateView |     from django.views.generic.edit import CreateView | ||||||
|  |     from myapp.models import Author | ||||||
| 
 | 
 | ||||||
|     class AjaxableResponseMixin(object): |     class AjaxableResponseMixin(object): | ||||||
|         """ |         """ | ||||||
|  |  | ||||||
|  | @ -258,6 +258,7 @@ mixin. | ||||||
| We can hook this into our URLs easily enough:: | We can hook this into our URLs easily enough:: | ||||||
| 
 | 
 | ||||||
|     # urls.py |     # urls.py | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|     from books.views import RecordInterest |     from books.views import RecordInterest | ||||||
| 
 | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|  | @ -440,6 +441,7 @@ Our new ``AuthorDetail`` looks like this:: | ||||||
|     from django.core.urlresolvers import reverse |     from django.core.urlresolvers import reverse | ||||||
|     from django.views.generic import DetailView |     from django.views.generic import DetailView | ||||||
|     from django.views.generic.edit import FormMixin |     from django.views.generic.edit import FormMixin | ||||||
|  |     from books.models import Author | ||||||
| 
 | 
 | ||||||
|     class AuthorInterestForm(forms.Form): |     class AuthorInterestForm(forms.Form): | ||||||
|         message = forms.CharField() |         message = forms.CharField() | ||||||
|  | @ -546,6 +548,8 @@ template as ``AuthorDisplay`` is using on ``GET``. | ||||||
| 
 | 
 | ||||||
| .. code-block:: python | .. code-block:: python | ||||||
| 
 | 
 | ||||||
|  |     from django.core.urlresolvers import reverse | ||||||
|  |     from django.http import HttpResponseForbidden | ||||||
|     from django.views.generic import FormView |     from django.views.generic import FormView | ||||||
|     from django.views.generic.detail import SingleObjectMixin |     from django.views.generic.detail import SingleObjectMixin | ||||||
| 
 | 
 | ||||||
|  | @ -657,6 +661,8 @@ own version of :class:`~django.views.generic.detail.DetailView` by mixing | ||||||
| :class:`~django.views.generic.detail.DetailView` before template | :class:`~django.views.generic.detail.DetailView` before template | ||||||
| rendering behavior has been mixed in):: | rendering behavior has been mixed in):: | ||||||
| 
 | 
 | ||||||
|  |     from django.views.generic.detail import BaseDetailView | ||||||
|  | 
 | ||||||
|     class JSONDetailView(JSONResponseMixin, BaseDetailView): |     class JSONDetailView(JSONResponseMixin, BaseDetailView): | ||||||
|         pass |         pass | ||||||
| 
 | 
 | ||||||
|  | @ -675,6 +681,8 @@ and override the implementation of | ||||||
| to defer to the appropriate subclass depending on the type of response that the | to defer to the appropriate subclass depending on the type of response that the | ||||||
| user requested:: | user requested:: | ||||||
| 
 | 
 | ||||||
|  |     from django.views.generic.detail import SingleObjectTemplateResponseMixin | ||||||
|  | 
 | ||||||
|     class HybridDetailView(JSONResponseMixin, SingleObjectTemplateResponseMixin, BaseDetailView): |     class HybridDetailView(JSONResponseMixin, SingleObjectTemplateResponseMixin, BaseDetailView): | ||||||
|         def render_to_response(self, context): |         def render_to_response(self, context): | ||||||
|             # Look for a 'format=json' GET argument |             # Look for a 'format=json' GET argument | ||||||
|  |  | ||||||
|  | @ -18,27 +18,29 @@ used to track the inventory for a series of online bookstores: | ||||||
| 
 | 
 | ||||||
| .. code-block:: python | .. code-block:: python | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Author(models.Model): |     class Author(models.Model): | ||||||
|        name = models.CharField(max_length=100) |         name = models.CharField(max_length=100) | ||||||
|        age = models.IntegerField() |         age = models.IntegerField() | ||||||
| 
 | 
 | ||||||
|     class Publisher(models.Model): |     class Publisher(models.Model): | ||||||
|        name = models.CharField(max_length=300) |         name = models.CharField(max_length=300) | ||||||
|        num_awards = models.IntegerField() |         num_awards = models.IntegerField() | ||||||
| 
 | 
 | ||||||
|     class Book(models.Model): |     class Book(models.Model): | ||||||
|        name = models.CharField(max_length=300) |         name = models.CharField(max_length=300) | ||||||
|        pages = models.IntegerField() |         pages = models.IntegerField() | ||||||
|        price = models.DecimalField(max_digits=10, decimal_places=2) |         price = models.DecimalField(max_digits=10, decimal_places=2) | ||||||
|        rating = models.FloatField() |         rating = models.FloatField() | ||||||
|        authors = models.ManyToManyField(Author) |         authors = models.ManyToManyField(Author) | ||||||
|        publisher = models.ForeignKey(Publisher) |         publisher = models.ForeignKey(Publisher) | ||||||
|        pubdate = models.DateField() |         pubdate = models.DateField() | ||||||
| 
 | 
 | ||||||
|     class Store(models.Model): |     class Store(models.Model): | ||||||
|        name = models.CharField(max_length=300) |         name = models.CharField(max_length=300) | ||||||
|        books = models.ManyToManyField(Book) |         books = models.ManyToManyField(Book) | ||||||
|        registered_users = models.PositiveIntegerField() |         registered_users = models.PositiveIntegerField() | ||||||
| 
 | 
 | ||||||
| Cheat sheet | Cheat sheet | ||||||
| =========== | =========== | ||||||
|  | @ -123,7 +125,7 @@ If you want to generate more than one aggregate, you just add another | ||||||
| argument to the ``aggregate()`` clause. So, if we also wanted to know | argument to the ``aggregate()`` clause. So, if we also wanted to know | ||||||
| the maximum and minimum price of all books, we would issue the query:: | the maximum and minimum price of all books, we would issue the query:: | ||||||
| 
 | 
 | ||||||
|     >>> from django.db.models import Avg, Max, Min, Count |     >>> from django.db.models import Avg, Max, Min | ||||||
|     >>> Book.objects.aggregate(Avg('price'), Max('price'), Min('price')) |     >>> Book.objects.aggregate(Avg('price'), Max('price'), Min('price')) | ||||||
|     {'price__avg': 34.35, 'price__max': Decimal('81.20'), 'price__min': Decimal('12.99')} |     {'price__avg': 34.35, 'price__max': Decimal('81.20'), 'price__min': Decimal('12.99')} | ||||||
| 
 | 
 | ||||||
|  | @ -148,6 +150,7 @@ the number of authors: | ||||||
| .. code-block:: python | .. code-block:: python | ||||||
| 
 | 
 | ||||||
|     # Build an annotated queryset |     # Build an annotated queryset | ||||||
|  |     >>> from django.db.models import Count | ||||||
|     >>> q = Book.objects.annotate(Count('authors')) |     >>> q = Book.objects.annotate(Count('authors')) | ||||||
|     # Interrogate the first object in the queryset |     # Interrogate the first object in the queryset | ||||||
|     >>> q[0] |     >>> q[0] | ||||||
|  | @ -192,6 +195,7 @@ and aggregate the related value. | ||||||
| For example, to find the price range of books offered in each store, | For example, to find the price range of books offered in each store, | ||||||
| you could use the annotation:: | you could use the annotation:: | ||||||
| 
 | 
 | ||||||
|  |     >>> from django.db.models import Max, Min | ||||||
|     >>> Store.objects.annotate(min_price=Min('books__price'), max_price=Max('books__price')) |     >>> Store.objects.annotate(min_price=Min('books__price'), max_price=Max('books__price')) | ||||||
| 
 | 
 | ||||||
| This tells Django to retrieve the ``Store`` model, join (through the | This tells Django to retrieve the ``Store`` model, join (through the | ||||||
|  | @ -222,7 +226,7 @@ For example, we can ask for all publishers, annotated with their respective | ||||||
| total book stock counters (note how we use ``'book'`` to specify the | total book stock counters (note how we use ``'book'`` to specify the | ||||||
| ``Publisher`` -> ``Book`` reverse foreign key hop):: | ``Publisher`` -> ``Book`` reverse foreign key hop):: | ||||||
| 
 | 
 | ||||||
|     >>> from django.db.models import Count, Min, Sum, Max, Avg |     >>> from django.db.models import Count, Min, Sum, Avg | ||||||
|     >>> Publisher.objects.annotate(Count('book')) |     >>> Publisher.objects.annotate(Count('book')) | ||||||
| 
 | 
 | ||||||
| (Every ``Publisher`` in the resulting ``QuerySet`` will have an extra attribute | (Every ``Publisher`` in the resulting ``QuerySet`` will have an extra attribute | ||||||
|  | @ -269,6 +273,7 @@ constraining the objects for which an annotation is calculated. For example, | ||||||
| you can generate an annotated list of all books that have a title starting | you can generate an annotated list of all books that have a title starting | ||||||
| with "Django" using the query:: | with "Django" using the query:: | ||||||
| 
 | 
 | ||||||
|  |     >>> from django.db.models import Count, Avg | ||||||
|     >>> Book.objects.filter(name__startswith="Django").annotate(num_authors=Count('authors')) |     >>> Book.objects.filter(name__startswith="Django").annotate(num_authors=Count('authors')) | ||||||
| 
 | 
 | ||||||
| When used with an ``aggregate()`` clause, a filter has the effect of | When used with an ``aggregate()`` clause, a filter has the effect of | ||||||
|  | @ -407,6 +412,8 @@ particularly, when counting things. | ||||||
| 
 | 
 | ||||||
| By way of example, suppose you have a model like this:: | By way of example, suppose you have a model like this:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Item(models.Model): |     class Item(models.Model): | ||||||
|         name = models.CharField(max_length=10) |         name = models.CharField(max_length=10) | ||||||
|         data = models.IntegerField() |         data = models.IntegerField() | ||||||
|  | @ -457,5 +464,6 @@ For example, if you wanted to calculate the average number of authors per | ||||||
| book you first annotate the set of books with the author count, then | book you first annotate the set of books with the author count, then | ||||||
| aggregate that author count, referencing the annotation field:: | aggregate that author count, referencing the annotation field:: | ||||||
| 
 | 
 | ||||||
|  |     >>> from django.db.models import Count, Avg | ||||||
|     >>> Book.objects.annotate(num_authors=Count('authors')).aggregate(Avg('num_authors')) |     >>> Book.objects.annotate(num_authors=Count('authors')).aggregate(Avg('num_authors')) | ||||||
|     {'num_authors__avg': 1.66} |     {'num_authors__avg': 1.66} | ||||||
|  |  | ||||||
|  | @ -62,6 +62,8 @@ For example, this custom ``Manager`` offers a method ``with_counts()``, which | ||||||
| returns a list of all ``OpinionPoll`` objects, each with an extra | returns a list of all ``OpinionPoll`` objects, each with an extra | ||||||
| ``num_responses`` attribute that is the result of an aggregate query:: | ``num_responses`` attribute that is the result of an aggregate query:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class PollManager(models.Manager): |     class PollManager(models.Manager): | ||||||
|         def with_counts(self): |         def with_counts(self): | ||||||
|             from django.db import connection |             from django.db import connection | ||||||
|  | @ -101,6 +103,8 @@ Modifying initial Manager QuerySets | ||||||
| A ``Manager``'s base ``QuerySet`` returns all objects in the system. For | A ``Manager``'s base ``QuerySet`` returns all objects in the system. For | ||||||
| example, using this model:: | example, using this model:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Book(models.Model): |     class Book(models.Model): | ||||||
|         title = models.CharField(max_length=100) |         title = models.CharField(max_length=100) | ||||||
|         author = models.CharField(max_length=50) |         author = models.CharField(max_length=50) | ||||||
|  | @ -236,7 +240,7 @@ class, but still customize the default manager. For example, suppose you have | ||||||
| this base class:: | this base class:: | ||||||
| 
 | 
 | ||||||
|     class AbstractBase(models.Model): |     class AbstractBase(models.Model): | ||||||
|         ... |         # ... | ||||||
|         objects = CustomManager() |         objects = CustomManager() | ||||||
| 
 | 
 | ||||||
|         class Meta: |         class Meta: | ||||||
|  | @ -246,14 +250,15 @@ If you use this directly in a subclass, ``objects`` will be the default | ||||||
| manager if you declare no managers in the base class:: | manager if you declare no managers in the base class:: | ||||||
| 
 | 
 | ||||||
|     class ChildA(AbstractBase): |     class ChildA(AbstractBase): | ||||||
|         ... |         # ... | ||||||
|         # This class has CustomManager as the default manager. |         # This class has CustomManager as the default manager. | ||||||
|  |         pass | ||||||
| 
 | 
 | ||||||
| If you want to inherit from ``AbstractBase``, but provide a different default | If you want to inherit from ``AbstractBase``, but provide a different default | ||||||
| manager, you can provide the default manager on the child class:: | manager, you can provide the default manager on the child class:: | ||||||
| 
 | 
 | ||||||
|     class ChildB(AbstractBase): |     class ChildB(AbstractBase): | ||||||
|         ... |         # ... | ||||||
|         # An explicit default manager. |         # An explicit default manager. | ||||||
|         default_manager = OtherManager() |         default_manager = OtherManager() | ||||||
| 
 | 
 | ||||||
|  | @ -274,9 +279,10 @@ it into the inheritance hierarchy *after* the defaults:: | ||||||
|             abstract = True |             abstract = True | ||||||
| 
 | 
 | ||||||
|     class ChildC(AbstractBase, ExtraManager): |     class ChildC(AbstractBase, ExtraManager): | ||||||
|         ... |         # ... | ||||||
|         # Default manager is CustomManager, but OtherManager is |         # Default manager is CustomManager, but OtherManager is | ||||||
|         # also available via the "extra_manager" attribute. |         # also available via the "extra_manager" attribute. | ||||||
|  |         pass | ||||||
| 
 | 
 | ||||||
| Note that while you can *define* a custom manager on the abstract model, you | Note that while you can *define* a custom manager on the abstract model, you | ||||||
| can't *invoke* any methods using the abstract model. That is:: | can't *invoke* any methods using the abstract model. That is:: | ||||||
|  | @ -349,8 +355,7 @@ the manager class:: | ||||||
| 
 | 
 | ||||||
|     class MyManager(models.Manager): |     class MyManager(models.Manager): | ||||||
|         use_for_related_fields = True |         use_for_related_fields = True | ||||||
| 
 |         # ... | ||||||
|         ... |  | ||||||
| 
 | 
 | ||||||
| If this attribute is set on the *default* manager for a model (only the | If this attribute is set on the *default* manager for a model (only the | ||||||
| default manager is considered in these situations), Django will use that class | default manager is considered in these situations), Django will use that class | ||||||
|  | @ -396,7 +401,8 @@ it, whereas the following will not work:: | ||||||
| 
 | 
 | ||||||
|     # BAD: Incorrect code |     # BAD: Incorrect code | ||||||
|     class MyManager(models.Manager): |     class MyManager(models.Manager): | ||||||
|         ... |         # ... | ||||||
|  |         pass | ||||||
| 
 | 
 | ||||||
|     # Sets the attribute on an instance of MyManager. Django will |     # Sets the attribute on an instance of MyManager. Django will | ||||||
|     # ignore this setting. |     # ignore this setting. | ||||||
|  | @ -404,7 +410,7 @@ it, whereas the following will not work:: | ||||||
|     mgr.use_for_related_fields = True |     mgr.use_for_related_fields = True | ||||||
| 
 | 
 | ||||||
|     class MyModel(models.Model): |     class MyModel(models.Model): | ||||||
|         ... |         # ... | ||||||
|         objects = mgr |         objects = mgr | ||||||
| 
 | 
 | ||||||
|     # End of incorrect code. |     # End of incorrect code. | ||||||
|  |  | ||||||
|  | @ -90,6 +90,8 @@ attributes. Be careful not to choose field names that conflict with the | ||||||
| 
 | 
 | ||||||
| Example:: | Example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Musician(models.Model): |     class Musician(models.Model): | ||||||
|         first_name = models.CharField(max_length=50) |         first_name = models.CharField(max_length=50) | ||||||
|         last_name = models.CharField(max_length=50) |         last_name = models.CharField(max_length=50) | ||||||
|  | @ -290,8 +292,11 @@ For example, if a ``Car`` model has a ``Manufacturer`` -- that is, a | ||||||
| ``Manufacturer`` makes multiple cars but each ``Car`` only has one | ``Manufacturer`` makes multiple cars but each ``Car`` only has one | ||||||
| ``Manufacturer`` -- use the following definitions:: | ``Manufacturer`` -- use the following definitions:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Manufacturer(models.Model): |     class Manufacturer(models.Model): | ||||||
|         # ... |         # ... | ||||||
|  |         pass | ||||||
| 
 | 
 | ||||||
|     class Car(models.Model): |     class Car(models.Model): | ||||||
|         manufacturer = models.ForeignKey(Manufacturer) |         manufacturer = models.ForeignKey(Manufacturer) | ||||||
|  | @ -340,8 +345,11 @@ For example, if a ``Pizza`` has multiple ``Topping`` objects -- that is, a | ||||||
| ``Topping`` can be on multiple pizzas and each ``Pizza`` has multiple toppings | ``Topping`` can be on multiple pizzas and each ``Pizza`` has multiple toppings | ||||||
| -- here's how you'd represent that:: | -- here's how you'd represent that:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Topping(models.Model): |     class Topping(models.Model): | ||||||
|         # ... |         # ... | ||||||
|  |         pass | ||||||
| 
 | 
 | ||||||
|     class Pizza(models.Model): |     class Pizza(models.Model): | ||||||
|         # ... |         # ... | ||||||
|  | @ -403,6 +411,8 @@ intermediate model. The intermediate model is associated with the | ||||||
| that will act as an intermediary. For our musician example, the code would look | that will act as an intermediary. For our musician example, the code would look | ||||||
| something like this:: | something like this:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Person(models.Model): |     class Person(models.Model): | ||||||
|         name = models.CharField(max_length=128) |         name = models.CharField(max_length=128) | ||||||
| 
 | 
 | ||||||
|  | @ -583,6 +593,7 @@ It's perfectly OK to relate a model to one from another app. To do this, import | ||||||
| the related model at the top of the file where your model is defined. Then, | the related model at the top of the file where your model is defined. Then, | ||||||
| just refer to the other model class wherever needed. For example:: | just refer to the other model class wherever needed. For example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|     from geography.models import ZipCode |     from geography.models import ZipCode | ||||||
| 
 | 
 | ||||||
|     class Restaurant(models.Model): |     class Restaurant(models.Model): | ||||||
|  | @ -630,6 +641,8 @@ Meta options | ||||||
| 
 | 
 | ||||||
| Give your model metadata by using an inner ``class Meta``, like so:: | Give your model metadata by using an inner ``class Meta``, like so:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Ox(models.Model): |     class Ox(models.Model): | ||||||
|         horn_length = models.IntegerField() |         horn_length = models.IntegerField() | ||||||
| 
 | 
 | ||||||
|  | @ -660,6 +673,8 @@ model. | ||||||
| 
 | 
 | ||||||
| For example, this model has a few custom methods:: | For example, this model has a few custom methods:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Person(models.Model): |     class Person(models.Model): | ||||||
|         first_name = models.CharField(max_length=50) |         first_name = models.CharField(max_length=50) | ||||||
|         last_name = models.CharField(max_length=50) |         last_name = models.CharField(max_length=50) | ||||||
|  | @ -729,6 +744,8 @@ A classic use-case for overriding the built-in methods is if you want something | ||||||
| to happen whenever you save an object. For example (see | to happen whenever you save an object. For example (see | ||||||
| :meth:`~Model.save` for documentation of the parameters it accepts):: | :meth:`~Model.save` for documentation of the parameters it accepts):: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Blog(models.Model): |     class Blog(models.Model): | ||||||
|         name = models.CharField(max_length=100) |         name = models.CharField(max_length=100) | ||||||
|         tagline = models.TextField() |         tagline = models.TextField() | ||||||
|  | @ -740,6 +757,8 @@ to happen whenever you save an object. For example (see | ||||||
| 
 | 
 | ||||||
| You can also prevent saving:: | You can also prevent saving:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Blog(models.Model): |     class Blog(models.Model): | ||||||
|         name = models.CharField(max_length=100) |         name = models.CharField(max_length=100) | ||||||
|         tagline = models.TextField() |         tagline = models.TextField() | ||||||
|  | @ -826,6 +845,8 @@ the child (and Django will raise an exception). | ||||||
| 
 | 
 | ||||||
| An example:: | An example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class CommonInfo(models.Model): |     class CommonInfo(models.Model): | ||||||
|         name = models.CharField(max_length=100) |         name = models.CharField(max_length=100) | ||||||
|         age = models.PositiveIntegerField() |         age = models.PositiveIntegerField() | ||||||
|  | @ -854,14 +875,16 @@ attribute. If a child class does not declare its own :ref:`Meta <meta-options>` | ||||||
| class, it will inherit the parent's :ref:`Meta <meta-options>`. If the child wants to | class, it will inherit the parent's :ref:`Meta <meta-options>`. If the child wants to | ||||||
| extend the parent's :ref:`Meta <meta-options>` class, it can subclass it. For example:: | extend the parent's :ref:`Meta <meta-options>` class, it can subclass it. For example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class CommonInfo(models.Model): |     class CommonInfo(models.Model): | ||||||
|         ... |         # ... | ||||||
|         class Meta: |         class Meta: | ||||||
|             abstract = True |             abstract = True | ||||||
|             ordering = ['name'] |             ordering = ['name'] | ||||||
| 
 | 
 | ||||||
|     class Student(CommonInfo): |     class Student(CommonInfo): | ||||||
|         ... |         # ... | ||||||
|         class Meta(CommonInfo.Meta): |         class Meta(CommonInfo.Meta): | ||||||
|             db_table = 'student_info' |             db_table = 'student_info' | ||||||
| 
 | 
 | ||||||
|  | @ -901,6 +924,8 @@ abstract base class (only), part of the name should contain | ||||||
| 
 | 
 | ||||||
| For example, given an app ``common/models.py``:: | For example, given an app ``common/models.py``:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Base(models.Model): |     class Base(models.Model): | ||||||
|         m2m = models.ManyToManyField(OtherModel, related_name="%(app_label)s_%(class)s_related") |         m2m = models.ManyToManyField(OtherModel, related_name="%(app_label)s_%(class)s_related") | ||||||
| 
 | 
 | ||||||
|  | @ -949,6 +974,8 @@ relationship introduces links between the child model and each of its parents | ||||||
| (via an automatically-created :class:`~django.db.models.OneToOneField`). | (via an automatically-created :class:`~django.db.models.OneToOneField`). | ||||||
| For example:: | For example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Place(models.Model): |     class Place(models.Model): | ||||||
|         name = models.CharField(max_length=50) |         name = models.CharField(max_length=50) | ||||||
|         address = models.CharField(max_length=80) |         address = models.CharField(max_length=80) | ||||||
|  | @ -998,7 +1025,7 @@ If the parent has an ordering and you don't want the child to have any natural | ||||||
| ordering, you can explicitly disable it:: | ordering, you can explicitly disable it:: | ||||||
| 
 | 
 | ||||||
|     class ChildModel(ParentModel): |     class ChildModel(ParentModel): | ||||||
|         ... |         # ... | ||||||
|         class Meta: |         class Meta: | ||||||
|             # Remove parent's ordering effect |             # Remove parent's ordering effect | ||||||
|             ordering = [] |             ordering = [] | ||||||
|  | @ -1061,15 +1088,21 @@ Proxy models are declared like normal models. You tell Django that it's a | ||||||
| proxy model by setting the :attr:`~django.db.models.Options.proxy` attribute of | proxy model by setting the :attr:`~django.db.models.Options.proxy` attribute of | ||||||
| the ``Meta`` class to ``True``. | the ``Meta`` class to ``True``. | ||||||
| 
 | 
 | ||||||
| For example, suppose you want to add a method to the ``Person`` model described | For example, suppose you want to add a method to the ``Person`` model. You can do it like this:: | ||||||
| above. You can do it like this:: | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|  |     class Person(models.Model): | ||||||
|  |         first_name = models.CharField(max_length=30) | ||||||
|  |         last_name = models.CharField(max_length=30) | ||||||
| 
 | 
 | ||||||
|     class MyPerson(Person): |     class MyPerson(Person): | ||||||
|         class Meta: |         class Meta: | ||||||
|             proxy = True |             proxy = True | ||||||
| 
 | 
 | ||||||
|         def do_something(self): |         def do_something(self): | ||||||
|             ... |             # ... | ||||||
|  |             pass | ||||||
| 
 | 
 | ||||||
| The ``MyPerson`` class operates on the same database table as its parent | The ``MyPerson`` class operates on the same database table as its parent | ||||||
| ``Person`` class. In particular, any new instances of ``Person`` will also be | ``Person`` class. In particular, any new instances of ``Person`` will also be | ||||||
|  | @ -1125,8 +1158,11 @@ classes will still be available. | ||||||
| Continuing our example from above, you could change the default manager used | Continuing our example from above, you could change the default manager used | ||||||
| when you query the ``Person`` model like this:: | when you query the ``Person`` model like this:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class NewManager(models.Manager): |     class NewManager(models.Manager): | ||||||
|         ... |         # ... | ||||||
|  |         pass | ||||||
| 
 | 
 | ||||||
|     class MyPerson(Person): |     class MyPerson(Person): | ||||||
|         objects = NewManager() |         objects = NewManager() | ||||||
|  |  | ||||||
|  | @ -17,6 +17,8 @@ models, which comprise a Weblog application: | ||||||
| 
 | 
 | ||||||
| .. code-block:: python | .. code-block:: python | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Blog(models.Model): |     class Blog(models.Model): | ||||||
|         name = models.CharField(max_length=100) |         name = models.CharField(max_length=100) | ||||||
|         tagline = models.TextField() |         tagline = models.TextField() | ||||||
|  |  | ||||||
|  | @ -27,6 +27,8 @@ to deal with that file. | ||||||
| Consider the following model, using an :class:`~django.db.models.ImageField` to | Consider the following model, using an :class:`~django.db.models.ImageField` to | ||||||
| store a photo:: | store a photo:: | ||||||
| 
 | 
 | ||||||
|  |     from django.db import models | ||||||
|  | 
 | ||||||
|     class Car(models.Model): |     class Car(models.Model): | ||||||
|         name = models.CharField(max_length=255) |         name = models.CharField(max_length=255) | ||||||
|         price = models.DecimalField(max_digits=5, decimal_places=2) |         price = models.DecimalField(max_digits=5, decimal_places=2) | ||||||
|  |  | ||||||
|  | @ -15,6 +15,7 @@ Basic file uploads | ||||||
| 
 | 
 | ||||||
| Consider a simple form containing a :class:`~django.forms.FileField`:: | Consider a simple form containing a :class:`~django.forms.FileField`:: | ||||||
| 
 | 
 | ||||||
|  |     # In forms.py... | ||||||
|     from django import forms |     from django import forms | ||||||
| 
 | 
 | ||||||
|     class UploadFileForm(forms.Form): |     class UploadFileForm(forms.Form): | ||||||
|  | @ -39,6 +40,7 @@ something like:: | ||||||
| 
 | 
 | ||||||
|     from django.http import HttpResponseRedirect |     from django.http import HttpResponseRedirect | ||||||
|     from django.shortcuts import render_to_response |     from django.shortcuts import render_to_response | ||||||
|  |     from .forms import UploadFileForm | ||||||
| 
 | 
 | ||||||
|     # Imaginary function to handle an uploaded file. |     # Imaginary function to handle an uploaded file. | ||||||
|     from somewhere import handle_uploaded_file |     from somewhere import handle_uploaded_file | ||||||
|  |  | ||||||
|  | @ -123,6 +123,8 @@ is ``(?P<name>pattern)``, where ``name`` is the name of the group and | ||||||
| 
 | 
 | ||||||
| Here's the above example URLconf, rewritten to use named groups:: | Here's the above example URLconf, rewritten to use named groups:: | ||||||
| 
 | 
 | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|         url(r'^articles/2003/$', 'news.views.special_case_2003'), |         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})/$', 'news.views.year_archive'), | ||||||
|  | @ -192,6 +194,8 @@ A convenient trick is to specify default parameters for your views' arguments. | ||||||
| Here's an example URLconf and view:: | Here's an example URLconf and view:: | ||||||
| 
 | 
 | ||||||
|     # URLconf |     # URLconf | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|         url(r'^blog/$', 'blog.views.page'), |         url(r'^blog/$', 'blog.views.page'), | ||||||
|         url(r'^blog/page(?P<num>\d+)/$', 'blog.views.page'), |         url(r'^blog/page(?P<num>\d+)/$', 'blog.views.page'), | ||||||
|  | @ -370,11 +374,15 @@ An included URLconf receives any captured parameters from parent URLconfs, so | ||||||
| the following example is valid:: | the following example is valid:: | ||||||
| 
 | 
 | ||||||
|     # In settings/urls/main.py |     # In settings/urls/main.py | ||||||
|  |     from django.conf.urls import include, patterns, url | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|         url(r'^(?P<username>\w+)/blog/', include('foo.urls.blog')), |         url(r'^(?P<username>\w+)/blog/', include('foo.urls.blog')), | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|     # In foo/urls/blog.py |     # In foo/urls/blog.py | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('foo.views', |     urlpatterns = patterns('foo.views', | ||||||
|         url(r'^$', 'blog.index'), |         url(r'^$', 'blog.index'), | ||||||
|         url(r'^archive/$', 'blog.archive'), |         url(r'^archive/$', 'blog.archive'), | ||||||
|  | @ -397,6 +405,8 @@ function. | ||||||
| 
 | 
 | ||||||
| For example:: | For example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('blog.views', |     urlpatterns = patterns('blog.views', | ||||||
|         url(r'^blog/(?P<year>\d{4})/$', 'year_archive', {'foo': 'bar'}), |         url(r'^blog/(?P<year>\d{4})/$', 'year_archive', {'foo': 'bar'}), | ||||||
|     ) |     ) | ||||||
|  | @ -427,11 +437,15 @@ For example, these two URLconf sets are functionally identical: | ||||||
| Set one:: | Set one:: | ||||||
| 
 | 
 | ||||||
|     # main.py |     # main.py | ||||||
|  |     from django.conf.urls import include, patterns, url | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|         url(r'^blog/', include('inner'), {'blogid': 3}), |         url(r'^blog/', include('inner'), {'blogid': 3}), | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|     # inner.py |     # inner.py | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|         url(r'^archive/$', 'mysite.views.archive'), |         url(r'^archive/$', 'mysite.views.archive'), | ||||||
|         url(r'^about/$', 'mysite.views.about'), |         url(r'^about/$', 'mysite.views.about'), | ||||||
|  | @ -440,11 +454,15 @@ Set one:: | ||||||
| Set two:: | Set two:: | ||||||
| 
 | 
 | ||||||
|     # main.py |     # main.py | ||||||
|  |     from django.conf.urls import include, patterns, url | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|         url(r'^blog/', include('inner')), |         url(r'^blog/', include('inner')), | ||||||
|     ) |     ) | ||||||
| 
 | 
 | ||||||
|     # inner.py |     # inner.py | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|         url(r'^archive/$', 'mysite.views.archive', {'blogid': 3}), |         url(r'^archive/$', 'mysite.views.archive', {'blogid': 3}), | ||||||
|         url(r'^about/$', 'mysite.views.about', {'blogid': 3}), |         url(r'^about/$', 'mysite.views.about', {'blogid': 3}), | ||||||
|  | @ -464,6 +482,8 @@ supported -- you can pass any callable object as the view. | ||||||
| 
 | 
 | ||||||
| For example, given this URLconf in "string" notation:: | For example, given this URLconf in "string" notation:: | ||||||
| 
 | 
 | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|         url(r'^archive/$', 'mysite.views.archive'), |         url(r'^archive/$', 'mysite.views.archive'), | ||||||
|         url(r'^about/$', 'mysite.views.about'), |         url(r'^about/$', 'mysite.views.about'), | ||||||
|  | @ -473,6 +493,7 @@ For example, given this URLconf in "string" notation:: | ||||||
| You can accomplish the same thing by passing objects rather than strings. Just | You can accomplish the same thing by passing objects rather than strings. Just | ||||||
| be sure to import the objects:: | be sure to import the objects:: | ||||||
| 
 | 
 | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|     from mysite.views import archive, about, contact |     from mysite.views import archive, about, contact | ||||||
| 
 | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|  | @ -485,6 +506,7 @@ The following example is functionally identical. It's just a bit more compact | ||||||
| because it imports the module that contains the views, rather than importing | because it imports the module that contains the views, rather than importing | ||||||
| each view individually:: | each view individually:: | ||||||
| 
 | 
 | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|     from mysite import views |     from mysite import views | ||||||
| 
 | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|  | @ -501,6 +523,7 @@ the view prefix (as explained in "The view prefix" above) will have no effect. | ||||||
| Note that :doc:`class based views</topics/class-based-views/index>` must be | Note that :doc:`class based views</topics/class-based-views/index>` must be | ||||||
| imported:: | imported:: | ||||||
| 
 | 
 | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|     from mysite.views import ClassBasedView |     from mysite.views import ClassBasedView | ||||||
| 
 | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|  | @ -612,6 +635,9 @@ It's fairly common to use the same view function in multiple URL patterns in | ||||||
| your URLconf. For example, these two URL patterns both point to the ``archive`` | your URLconf. For example, these two URL patterns both point to the ``archive`` | ||||||
| view:: | view:: | ||||||
| 
 | 
 | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|  |     from mysite.views import archive | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|         url(r'^archive/(\d{4})/$', archive), |         url(r'^archive/(\d{4})/$', archive), | ||||||
|         url(r'^archive-summary/(\d{4})/$', archive, {'summary': True}), |         url(r'^archive-summary/(\d{4})/$', archive, {'summary': True}), | ||||||
|  | @ -630,6 +656,9 @@ matching. | ||||||
| 
 | 
 | ||||||
| Here's the above example, rewritten to use named URL patterns:: | Here's the above example, rewritten to use named URL patterns:: | ||||||
| 
 | 
 | ||||||
|  |     from django.conf.urls import patterns, url | ||||||
|  |     from mysite.views import archive | ||||||
|  | 
 | ||||||
|     urlpatterns = patterns('', |     urlpatterns = patterns('', | ||||||
|         url(r'^archive/(\d{4})/$', archive, name="full-archive"), |         url(r'^archive/(\d{4})/$', archive, name="full-archive"), | ||||||
|         url(r'^archive-summary/(\d{4})/$', archive, {'summary': True}, name="arch-summary"), |         url(r'^archive-summary/(\d{4})/$', archive, {'summary': True}, name="arch-summary"), | ||||||
|  | @ -803,6 +832,8 @@ However, you can also ``include()`` a 3-tuple containing:: | ||||||
| 
 | 
 | ||||||
| For example:: | For example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.conf.urls import include, patterns, url | ||||||
|  | 
 | ||||||
|     help_patterns = patterns('', |     help_patterns = patterns('', | ||||||
|         url(r'^basic/$', 'apps.help.views.views.basic'), |         url(r'^basic/$', 'apps.help.views.views.basic'), | ||||||
|         url(r'^advanced/$', 'apps.help.views.views.advanced'), |         url(r'^advanced/$', 'apps.help.views.views.advanced'), | ||||||
|  |  | ||||||
|  | @ -70,6 +70,8 @@ documentation.  Just return an instance of one of those subclasses instead of | ||||||
| a normal :class:`~django.http.HttpResponse` in order to signify an error. For | a normal :class:`~django.http.HttpResponse` in order to signify an error. For | ||||||
| example:: | example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.http import HttpResponse, HttpResponseNotFound | ||||||
|  | 
 | ||||||
|     def my_view(request): |     def my_view(request): | ||||||
|         # ... |         # ... | ||||||
|         if foo: |         if foo: | ||||||
|  | @ -83,6 +85,8 @@ the :class:`~django.http.HttpResponse` documentation, you can also pass the | ||||||
| HTTP status code into the constructor for :class:`~django.http.HttpResponse` | HTTP status code into the constructor for :class:`~django.http.HttpResponse` | ||||||
| to create a return class for any status code you like. For example:: | to create a return class for any status code you like. For example:: | ||||||
| 
 | 
 | ||||||
|  |     from django.http import HttpResponse | ||||||
|  | 
 | ||||||
|     def my_view(request): |     def my_view(request): | ||||||
|         # ... |         # ... | ||||||
| 
 | 
 | ||||||
|  | @ -110,6 +114,8 @@ standard error page for your application, along with an HTTP error code 404. | ||||||
| Example usage:: | Example usage:: | ||||||
| 
 | 
 | ||||||
|     from django.http import Http404 |     from django.http import Http404 | ||||||
|  |     from django.shortcuts import render_to_response | ||||||
|  |     from polls.models import Poll | ||||||
| 
 | 
 | ||||||
|     def detail(request, poll_id): |     def detail(request, poll_id): | ||||||
|         try: |         try: | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 Marc Tamlyn
						Marc Tamlyn