Python列表追加行为

时间:2011-08-31 10:00:41

标签: python list

真的不知道如何制定问题......

假设我执行以下操作:

    >>> l = [[]]*2
    >>> l
    [[], []]
    >>> l[0].append(1)
    >>> l
    [[1], [1]]

为什么1会被附加到两个列表中?

4 个答案:

答案 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)

展示内存布局的差异:

listOfLists = [[]] * 3
listOfListsRange = [[] for i in range(0, 3)]

enter image description here