2013-12-21 59 views
4

我正在尝试创建一个可以附加到for循环中的列表的字典。但是,如果我使用fromkeys创建字典,则列表将成为“指针”的副本,而不是新列表。例如,创建与列表不同的空白列表的字典

newdict = dict.fromkeys(range(10), [])

- 或 -

newdict = dict.fromkeys(range(10), list())

两者产生相同的数据结构,具有相同的列表作为值对的字典。所以,当任何密钥更新时,例如 - newdict[0].append(100)print newdict相应的输出是:

{0: [100], 1: [100], 2: [100], 3: [100], 4: [100], 5: [100], 6: [100], 7: [100], 8: [100], 9: [100]}

如何避免这种情况,而不必通过一个迭代的for循环有什么想法?提前致谢。

+3

轻微:您的意思是'newdict [0] .append(100)',或'newdict [0] + = [100]',而不是'newdict [0] = 100'。 – DSM

+0

我没有得到3.3.3的这种行为:'newdict [0] = 100'产生'{0:100,1:[],2:[],3:[],4:[],5: [],6:[],7:[],8:[],9:[]}'... – MattDMo

+0

@DSM - 是的,谢谢我纠正错误。 – paulski

回答

5

两种最常见的方法是使用字典理解:

>>> d = {k: [] for k in range(10)} 
>>> d[3].append(100) 
>>> d 
{0: [], 1: [], 2: [], 3: [100], 4: [], 5: [], 6: [], 7: [], 8: [], 9: []} 

或者使用defaultdict和放弃设置任何按键都:

>>> from collections import defaultdict 
>>> d = defaultdict(list) 
>>> d 
defaultdict(<type 'list'>, {}) 
>>> d[9].append(100) 
>>> d 
defaultdict(<type 'list'>, {9: [100]}) 

作为第三种选择,通过使用setdefault - 例如d.setdefault(k, []),而不是d[k],像defaultdict情况下,你能避免需要预设[]

>>> d = {} 
>>> d.setdefault(3, []).append(100) 
>>> d 
{3: [100]} 
4

也许是词典理解?

​​
+0

他不想使用for循环 – thefourtheye

+4

@thefourtheye我不确定我会考虑理解为循环。 – Xymostech

+0

如果不需要在for循环中遍历问题意味着什么...... – thefourtheye

0

我想你想要做的

newdict[0].append(100) 

吧?

0

fromkeysdict类的静态方法。默认行为是设计一组字典键的设置为值,如设置了多组计数器:

>>> d={}.fromkeys('abc',0) 
>>> d 
{'a': 0, 'c': 0, 'b': 0} 
>>> d['a']+=1 
>>> d 
{'a': 1, 'c': 0, 'b': 0} 

可以补丁它呼吁每个元素的功能:

>>> class FixFromKeys(dict): 
...  def fromkeys(cls, seq, func): 
...   return {key:func() for key in seq} 
... 
>>> d=FixFromKeys().fromkeys([1,2,3],list) 
>>> d[1].append(1) 
>>> d 
{1: [1], 2: [], 3: []}