真的不知道如何制定问题......
假设我执行以下操作:
>>> l = [[]]*2
>>> l
[[], []]
>>> l[0].append(1)
>>> l
[[1], [1]]
为什么1会被附加到两个列表中?
答案 0 :(得分:19)
[[]]*2
是对相同列表的两个引用的列表。你要附加它然后再看两次。
答案 1 :(得分:12)
因为实际上只有一个列表。考虑一下:
>>> l = [[]]
>>> l2 = l*2
>>> l2[0] is l[0]
True
>>> l2[1] is l[0]
True
在列表上执行的 *2
不会复制列表,但会返回填充相同引用的长度为2
的列表。
你可能想要的是:
>>> l = [[] for _ in xrange(2)]
正如@Asterisk在评论中提到的那样,所有常见集合都会暴露相同的行为。因此,根据经验,最好仅对具有值语义的不可变类型使用乘法。
答案 2 :(得分:1)
这是我如何初始化列表列表。行变化最慢。
nrows = 3; ncols = 5
l_of_ls = [[0]*ncols for i in range(nrows )]
for rix, r in enumerate(l_of_ls):
for cix, c in enumerate(r):
print rix, cix, 'val = ',c
<强> RESULT 强>
0 0 val = 0
0 1 val = 0
0 2 val = 0
0 3 val = 0
0 4 val = 0
1 0 val = 0
1 1 val = 0
1 2 val = 0
1 3 val = 0
1 4 val = 0
2 0 val = 0
2 1 val = 0
2 2 val = 0
2 3 val = 0
2 4 val = 0
值得注意的是索引目的
for rix in range(nrows):
for cix in range(ncols):
print l_of_ls[rix][cix],
print
<强> RESULT 强>
0 0 0 0 0
0 0 0 0 0
0 0 0 0 0
答案 3 :(得分:1)