PEP 274 has been updated to reflect current reality.
This commit is contained in:
parent
954c3684ce
commit
1edb8f9940
62
pep-0274.txt
62
pep-0274.txt
|
@ -2,11 +2,11 @@ PEP: 274
|
||||||
Title: Dict Comprehensions
|
Title: Dict Comprehensions
|
||||||
Version: $Revision$
|
Version: $Revision$
|
||||||
Last-Modified: $Date$
|
Last-Modified: $Date$
|
||||||
Author: barry@python.org (Barry Warsaw)
|
Author: Barry Warsaw <barry@python.org>
|
||||||
Status: Withdrawn
|
Status: Accepted
|
||||||
Type: Standards Track
|
Type: Standards Track
|
||||||
Created: 25-Oct-2001
|
Created: 25-Oct-2001
|
||||||
Python-Version: 2.3
|
Python-Version: 2.7, 3.0 (originally 2.3)
|
||||||
Post-History: 29-Oct-2001
|
Post-History: 29-Oct-2001
|
||||||
|
|
||||||
|
|
||||||
|
@ -19,13 +19,20 @@ Abstract
|
||||||
very similar to list comprehensions, except that they produce
|
very similar to list comprehensions, except that they produce
|
||||||
Python dictionary objects instead of list objects.
|
Python dictionary objects instead of list objects.
|
||||||
|
|
||||||
|
|
||||||
Resolution
|
Resolution
|
||||||
|
|
||||||
This PEP is withdrawn. Substantially all of its benefits were
|
This PEP was originally written for inclusion in Python 2.3. It
|
||||||
subsumed by generator expressions coupled with the dict() constructor.
|
was withdrawn after observation that substantially all of its
|
||||||
|
benefits were subsumed by generator expressions coupled with the
|
||||||
|
dict() constructor.
|
||||||
|
|
||||||
However, Python 3.0 introduces this exact feature, as well as the
|
However, Python 2.7 and 3.0 introduces this exact feature, as well
|
||||||
closely related set comprehensions.
|
as the closely related set comprehensions. On 2012-04-09, the PEP
|
||||||
|
was changed to reflect this reality by updating its Status to
|
||||||
|
Accepted, and updating the Python-Version field. The Open
|
||||||
|
Questions section was also removed since these have been long
|
||||||
|
resolved by the current implementation.
|
||||||
|
|
||||||
|
|
||||||
Proposed Solution
|
Proposed Solution
|
||||||
|
@ -33,10 +40,9 @@ Proposed Solution
|
||||||
Dict comprehensions are just like list comprehensions, except that
|
Dict comprehensions are just like list comprehensions, except that
|
||||||
you group the expression using curly braces instead of square
|
you group the expression using curly braces instead of square
|
||||||
braces. Also, the left part before the `for' keyword expresses
|
braces. Also, the left part before the `for' keyword expresses
|
||||||
both a key and a value, separated by a colon. (There is an
|
both a key and a value, separated by a colon. The notation is
|
||||||
optional part of this PEP that allows you to use a shortcut to
|
specifically designed to remind you of list comprehensions as
|
||||||
express just the value.) The notation is specifically designed to
|
applied to dictionaries.
|
||||||
remind you of list comprehensions as applied to dictionaries.
|
|
||||||
|
|
||||||
|
|
||||||
Rationale
|
Rationale
|
||||||
|
@ -65,7 +71,7 @@ Semantics
|
||||||
|
|
||||||
The semantics of dict comprehensions can actually be demonstrated
|
The semantics of dict comprehensions can actually be demonstrated
|
||||||
in stock Python 2.2, by passing a list comprehension to the
|
in stock Python 2.2, by passing a list comprehension to the
|
||||||
builtin dictionary constructor:
|
built-in dictionary constructor:
|
||||||
|
|
||||||
>>> dict([(i, chr(65+i)) for i in range(4)])
|
>>> dict([(i, chr(65+i)) for i in range(4)])
|
||||||
|
|
||||||
|
@ -73,7 +79,7 @@ Semantics
|
||||||
|
|
||||||
>>> {i : chr(65+i) for i in range(4)}
|
>>> {i : chr(65+i) for i in range(4)}
|
||||||
|
|
||||||
The dictionary constructor approach has two dictinct disadvantages
|
The dictionary constructor approach has two distinct disadvantages
|
||||||
from the proposed syntax though. First, it isn't as legible as a
|
from the proposed syntax though. First, it isn't as legible as a
|
||||||
dict comprehension. Second, it forces the programmer to create an
|
dict comprehension. Second, it forces the programmer to create an
|
||||||
in-core list object first, which could be expensive.
|
in-core list object first, which could be expensive.
|
||||||
|
@ -104,36 +110,10 @@ Examples
|
||||||
2, 3): 5}
|
2, 3): 5}
|
||||||
|
|
||||||
|
|
||||||
Open Issues
|
|
||||||
|
|
||||||
- There is one further shortcut we could adopt. Suppose we wanted
|
|
||||||
to create a set of items, such as in the "list_of_email_addrs"
|
|
||||||
example above. Here, we're simply taking the target of the for
|
|
||||||
loop and turning that into the key for the dict comprehension.
|
|
||||||
The assertion is that this would be a common idiom, so the
|
|
||||||
shortcut below allows for an easy spelling of it, by allow us to
|
|
||||||
omit the "key :" part of the left hand clause:
|
|
||||||
|
|
||||||
>>> print {1 for x in list_of_email_addrs}
|
|
||||||
{'barry@zope.com' : 1, 'barry@python.org' : 1, 'guido@python.org' : 1}
|
|
||||||
|
|
||||||
Or say we wanted to map email addresses to the MX record handling
|
|
||||||
their mail:
|
|
||||||
|
|
||||||
>>> print {mx_for_addr(x) for x in list_of_email_addrs}
|
|
||||||
{'barry@zope.com' : 'mail.zope.com',
|
|
||||||
'barry@python.org' : 'mail.python.org,
|
|
||||||
'guido@python.org' : 'mail.python.org,
|
|
||||||
}
|
|
||||||
|
|
||||||
Questions: what about nested loops? Where does the key come
|
|
||||||
from? The shortcut probably doesn't save much typing, and comes
|
|
||||||
at the expense of legibility, so it's of dubious value.
|
|
||||||
|
|
||||||
|
|
||||||
Implementation
|
Implementation
|
||||||
|
|
||||||
TBD
|
All implementation details were resolved in the Python 2.7 and 3.0
|
||||||
|
time-frame.
|
||||||
|
|
||||||
|
|
||||||
References
|
References
|
||||||
|
|
Loading…
Reference in New Issue