mirror of https://github.com/django/django.git
Refs #26021 -- Used hanging indentation in some doc examples.
This commit is contained in:
parent
5238af3257
commit
e475e84970
|
@ -921,8 +921,10 @@ For example, suppose you have these models::
|
||||||
toppings = models.ManyToManyField(Topping)
|
toppings = models.ManyToManyField(Topping)
|
||||||
|
|
||||||
def __str__(self): # __unicode__ on Python 2
|
def __str__(self): # __unicode__ on Python 2
|
||||||
return "%s (%s)" % (self.name, ", ".join(topping.name
|
return "%s (%s)" % (
|
||||||
for topping in self.toppings.all()))
|
self.name,
|
||||||
|
", ".join(topping.name or topping in self.toppings.all()),
|
||||||
|
)
|
||||||
|
|
||||||
and run::
|
and run::
|
||||||
|
|
||||||
|
@ -1669,8 +1671,11 @@ This is meant as a shortcut to boilerplatish code. For example::
|
||||||
This pattern gets quite unwieldy as the number of fields in a model goes up.
|
This pattern gets quite unwieldy as the number of fields in a model goes up.
|
||||||
The above example can be rewritten using ``get_or_create()`` like so::
|
The above example can be rewritten using ``get_or_create()`` like so::
|
||||||
|
|
||||||
obj, created = Person.objects.get_or_create(first_name='John', last_name='Lennon',
|
obj, created = Person.objects.get_or_create(
|
||||||
defaults={'birthday': date(1940, 10, 9)})
|
first_name='John',
|
||||||
|
last_name='Lennon',
|
||||||
|
defaults={'birthday': date(1940, 10, 9)},
|
||||||
|
)
|
||||||
|
|
||||||
Any keyword arguments passed to ``get_or_create()`` — *except* an optional one
|
Any keyword arguments passed to ``get_or_create()`` — *except* an optional one
|
||||||
called ``defaults`` — will be used in a :meth:`get()` call. If an object is
|
called ``defaults`` — will be used in a :meth:`get()` call. If an object is
|
||||||
|
|
|
@ -317,7 +317,7 @@ Sample usage::
|
||||||
>>> feed.add_item(
|
>>> feed.add_item(
|
||||||
... title="Hello",
|
... title="Hello",
|
||||||
... link="http://www.holovaty.com/test/",
|
... link="http://www.holovaty.com/test/",
|
||||||
... description="Testing."
|
... description="Testing.",
|
||||||
... )
|
... )
|
||||||
>>> with open('test.rss', 'w') as fp:
|
>>> with open('test.rss', 'w') as fp:
|
||||||
... feed.write(fp, 'utf-8')
|
... feed.write(fp, 'utf-8')
|
||||||
|
@ -629,15 +629,19 @@ escaping HTML.
|
||||||
|
|
||||||
So, instead of writing::
|
So, instead of writing::
|
||||||
|
|
||||||
mark_safe("%s <b>%s</b> %s" % (some_html,
|
mark_safe("%s <b>%s</b> %s" % (
|
||||||
escape(some_text),
|
some_html,
|
||||||
escape(some_other_text),
|
escape(some_text),
|
||||||
))
|
escape(some_other_text),
|
||||||
|
))
|
||||||
|
|
||||||
You should instead use::
|
You should instead use::
|
||||||
|
|
||||||
format_html("{} <b>{}</b> {}",
|
format_html("{} <b>{}</b> {}",
|
||||||
mark_safe(some_html), some_text, some_other_text)
|
mark_safe(some_html),
|
||||||
|
some_text,
|
||||||
|
some_other_text,
|
||||||
|
)
|
||||||
|
|
||||||
This has the advantage that you don't need to apply :func:`escape` to each
|
This has the advantage that you don't need to apply :func:`escape` to each
|
||||||
argument and risk a bug and an XSS vulnerability if you forget one.
|
argument and risk a bug and an XSS vulnerability if you forget one.
|
||||||
|
@ -658,8 +662,10 @@ escaping HTML.
|
||||||
``args_generator`` should be an iterator that returns the sequence of
|
``args_generator`` should be an iterator that returns the sequence of
|
||||||
``args`` that will be passed to :func:`format_html`. For example::
|
``args`` that will be passed to :func:`format_html`. For example::
|
||||||
|
|
||||||
format_html_join('\n', "<li>{} {}</li>", ((u.first_name, u.last_name)
|
format_html_join(
|
||||||
for u in users))
|
'\n', "<li>{} {}</li>",
|
||||||
|
((u.first_name, u.last_name) for u in users)
|
||||||
|
)
|
||||||
|
|
||||||
.. function:: strip_tags(value)
|
.. function:: strip_tags(value)
|
||||||
|
|
||||||
|
|
|
@ -519,8 +519,7 @@ will return ``Blog`` objects that have an empty ``name`` on the ``author`` and
|
||||||
also those which have an empty ``author`` on the ``entry``. If you don't want
|
also those which have an empty ``author`` on the ``entry``. If you don't want
|
||||||
those latter objects, you could write::
|
those latter objects, you could write::
|
||||||
|
|
||||||
Blog.objects.filter(entry__authors__isnull=False,
|
Blog.objects.filter(entry__authors__isnull=False, entry__authors__name__isnull=True)
|
||||||
entry__authors__name__isnull=True)
|
|
||||||
|
|
||||||
Spanning multi-valued relationships
|
Spanning multi-valued relationships
|
||||||
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
|
||||||
|
@ -556,14 +555,12 @@ select all blogs that contain entries with both *"Lennon"* in the headline
|
||||||
and that were published in 2008 (the same entry satisfying both conditions),
|
and that were published in 2008 (the same entry satisfying both conditions),
|
||||||
we would write::
|
we would write::
|
||||||
|
|
||||||
Blog.objects.filter(entry__headline__contains='Lennon',
|
Blog.objects.filter(entry__headline__contains='Lennon', entry__pub_date__year=2008)
|
||||||
entry__pub_date__year=2008)
|
|
||||||
|
|
||||||
To select all blogs that contain an entry with *"Lennon"* in the headline
|
To select all blogs that contain an entry with *"Lennon"* in the headline
|
||||||
**as well as** an entry that was published in 2008, we would write::
|
**as well as** an entry that was published in 2008, we would write::
|
||||||
|
|
||||||
Blog.objects.filter(entry__headline__contains='Lennon').filter(
|
Blog.objects.filter(entry__headline__contains='Lennon').filter(entry__pub_date__year=2008)
|
||||||
entry__pub_date__year=2008)
|
|
||||||
|
|
||||||
Suppose there is only one blog that had both entries containing *"Lennon"* and
|
Suppose there is only one blog that had both entries containing *"Lennon"* and
|
||||||
entries from 2008, but that none of the entries from 2008 contained *"Lennon"*.
|
entries from 2008, but that none of the entries from 2008 contained *"Lennon"*.
|
||||||
|
|
|
@ -1703,9 +1703,11 @@ and contents::
|
||||||
class EmailTest(TestCase):
|
class EmailTest(TestCase):
|
||||||
def test_send_email(self):
|
def test_send_email(self):
|
||||||
# Send message.
|
# Send message.
|
||||||
mail.send_mail('Subject here', 'Here is the message.',
|
mail.send_mail(
|
||||||
|
'Subject here', 'Here is the message.',
|
||||||
'from@example.com', ['to@example.com'],
|
'from@example.com', ['to@example.com'],
|
||||||
fail_silently=False)
|
fail_silently=False,
|
||||||
|
)
|
||||||
|
|
||||||
# Test that one message has been sent.
|
# Test that one message has been sent.
|
||||||
self.assertEqual(len(mail.outbox), 1)
|
self.assertEqual(len(mail.outbox), 1)
|
||||||
|
|
Loading…
Reference in New Issue