This issue tracker has been migrated to GitHub, and is currently read-only.
For more information, see the GitHub FAQs in the Python's Developer Guide.

classification
Title: dictionary literal should not allow duplicate keys
Type: behavior Stage: resolved
Components: Interpreter Core Versions: Python 3.4
process
Status: closed Resolution: duplicate
Dependencies: Superseder: evaluating literal dict with repeated keys gives no warnings/errors
View: 16385
Assigned To: Nosy List: Luigi Semenzato, jfine2358, r.david.murray
Priority: normal Keywords:

Created on 2016-05-02 17:50 by Luigi Semenzato, last changed 2022-04-11 14:58 by admin. This issue is now closed.

Messages (3)
msg264657 - (view) Author: Luigi Semenzato (Luigi Semenzato) Date: 2016-05-02 17:50
This was already discussed and rejected at https://bugs.python.org/issue16385.  I am reopening because I am not convinced that the discussion presented all arguments properly.

The original problem description:

lives_in = { 'lion': ['Africa', 'America],
             'parrot': ['Europe'],
             #... 100+ more rows here
             'lion': ['Europe'],
             #... 100+ more rows here
           }

The above constructor overwrites the 'lion' entry silently, often causing unexpected behavior.

These are the arguments presented in favor of the rejection, followed by my rebuttals.

1. "An error is out of the question for compatibility reasons".  No real rebuttal here, except I wonder if exceptions are ever made and under what circumstances.  I should point out that a warning may also create incompatibilities.

2. "There are ways to rewrite this as a loop on a list".  Yes of course, but the entire point of the dictionary literal is to offer a concise and convenient notation for entering a dictionary as program text.

3. "Being able to re-write keys is fundamental to Python dicts and why they can be used for Python's mutable namespaces".  This is fine but it applies to the data structure, not the literal constructor.

4. "A code generator could depend on being able to write duplicate keys without having to go back and erase previous output".  Yes, but it seems wrong to facilitate automated code generation at the expense of human code writing.  For hand-written code, I claim that in most (all?) cases it would be preferable to have the compiler detect key duplications.  It is easier for an automated code generator to check for duplications than it is for a human.

5. "There is already pylint".  True, but it forces an additional step, and seems like a cop-out for not wanting to do the "right thing" in the language.

For context, someone ran into this problem in my team at Google.  We fixed it using pylint, but I really don't see the point of having these constructor semantics.  From the discussions I have seen, it seems just an oversight in the implementation/specification of dictionary literals (search keywords: dict constructor, dict literal).  I'd be happy to hear stronger reasoning in favor of the status quo.
msg264661 - (view) Author: R. David Murray (r.david.murray) * (Python committer) Date: 2016-05-02 19:00
Since this has been previously rejected, I'm closing this issue as a duplicate.

If you want to reopen the discussion of the merits, the python-ideas mailing list is the appropriate forum.  I encourage you to raise it there.
msg337331 - (view) Author: Jonathan Fine (jfine2358) * Date: 2019-03-06 17:06
I mention this issue, and related pages, in
[Python-ideas] dict literal allows duplicate keys
https://mail.python.org/pipermail/python-ideas/2019-March/055717.html

It arises from a discussion of PEP 584 -- Add + and - operators to the built-in dict class.

Please send any follow-up to python-ideas (or #16385).
History
Date User Action Args
2022-04-11 14:58:30adminsetgithub: 71097
2019-03-06 17:06:01jfine2358setnosy: + jfine2358
messages: + msg337331
2016-05-02 19:00:36r.david.murraysetstatus: open -> closed

superseder: evaluating literal dict with repeated keys gives no warnings/errors

nosy: + r.david.murray
messages: + msg264661
resolution: duplicate
stage: resolved
2016-05-02 17:50:17Luigi Semenzatocreate