0

我创建了一个 SETTINGS 对象,namedtuple认为其中包含的列表是不可变的。我错了,因为在整个链中,只使用了对完全可变字典中原始列表的引用。

因此,当我调用.pop()我的列表时,它也会将它从我的 not-as-immutable-as-I-thought 中删除namedtuple。现在我在#python 一段时间后明白了为什么这一切都会发生。

我想知道的是:如何将 SETTINGS 创建namedtuple为行尾?只是数据,没有对任何其他对象的引用,以一种用户可编辑的方式?我觉得这dict是人类最容易阅读/编辑的数据结构,因此我dictnamedtuple.

>>> from collections import namedtuple
>>>
>>> _settings = {
...     'ROOM_NAMES': [
...         'Master Bedroom',
...         'Bath',
...         'Kitchen',
...         'Study',
...     ],
... }
>>> _Settings = namedtuple('_Settings', [k for k in _settings.keys()])
>>> SETTINGS = _Settings(**_settings)
>>>
>>> names = SETTINGS.ROOM_NAMES
>>> names
['Master Bedroom', 'Bath', 'Kitchen', 'Study']
>>> type(names)
<class 'list'>
>>> # POP 'Study' OFF OF THE LIST
>>> name = names.pop() 
>>>
>>> # THIS IS WHAT I EXPECT              
>>> name in names                    
False
>>>
>>> # MISSING HERE AS THIS IS THE END OF THE LINE
>>> name in _settings['ROOM_NAMES']  
False
>>>
>>> # MISSING HERE FROM MY NAMEDTUPLE IN THE MIDDLE OF THE LINE
>>> name in SETTINGS.ROOM_NAMES      
False
>>>
4

1 回答 1

2

我认为您对元组的实际工作方式感到困惑。即使是“真正的”元组也不会使包含的对象不可变,只是元组本身:

>>> x  = [1,2,3]
>>> t = (x,0,3)
>>> t[0].append(4)
>>> t
([1, 2, 3, 4], 0, 3)

我猜你想要做的是.copy()在你开始变异之前的列表。

>>> a = x.copy()
>>> t = (a,0,1)
>>> t[0].append(5)
>>> t
([1, 2, 3, 4, 5], 0, 1)
>>> x
[1, 2, 3, 4]
于 2014-07-10T03:28:36.063 回答