1

可能重复:
两个单独的 python 列表充当一个

此代码创建一个列表字典,键位于usens. 列表中满是0s

usens = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 14, 110, 111, 112, 113, 114,
         115, 116, 117, 118, 119, 302, 303, 306, 307, 308, 370, 371, 500,
         501, 1000, 1010, 1020, 1100, 1200, 1201, 1202, 2000, 2001, 2002
         ]
empty = [[0]*length]*len(usens)
data = dict(zip(usens, empty))
pprint.pprint(data, indent=5)

data[0][0] += 1
pprint.pprint(data, indent=5)

第一个漂亮的打印返回预期的(去除模糊):

{0: [0, 0, 0, 0, 0],
 1: [0, 0, 0, 0, 0],
 2: [0, 0, 0, 0, 0],
 3: [0, 0, 0, 0, 0],
 4: [0, 0, 0, 0, 0],
 5: [0, 0, 0, 0, 0],
 .....
 2001: [0, 0, 0, 0, 0],
 2002: [0, 0, 0, 0, 0]}

然后我这样做:data[0][0] += 1,期望第一个列表(索引0)以 开头1,但没有其他改变。

但是,所有列表都已修改:

{0: [1, 0, 0, 0, 0],
 1: [1, 0, 0, 0, 0],
 2: [1, 0, 0, 0, 0],
 3: [1, 0, 0, 0, 0],
 4: [1, 0, 0, 0, 0],
 .....
 2001: [1, 0, 0, 0, 0],
 2002: [1, 0, 0, 0, 0]}

为什么,我怎样才能使它只修改一个列表?

4

2 回答 2

3

empty = [[0]*length]*len(usens)将创建len(usens)相同列表的副本,这len(usens)与具有相同内容的列表不同。

试试empty = [[0]*length for i in range(len(usens))]

于 2012-12-07T20:40:52.357 回答
1

使用*创建副本;因为[0]它很好,因为它正在复制一个不可变的标量;但外部*创建相同列表的副本(即,复制引用)。你可以使用类似的东西:

empty = [0]*5
data = {n:list(empty) for n in usens}

(一个字典理解)来创建你的列表(如果使用 Python 2.7+)。使用list制作副本。

于 2012-12-07T20:48:13.580 回答