1. 程式人生 > >python 踩坑系列之巢狀列表建立

python 踩坑系列之巢狀列表建立

1.初始化列表及修改

    初始化列表有很多方法,其中之一可以通過*來初始化:

a = [[]]*3
print a
>>> [[], [], []]

通過這個方法獲取了一個包含三個空list的巢狀列表,下面對這個列表進行修改:

a[0].append(1)
print a
>>> [[1], [1], [1]]

通過輸出,我們發現我們只是修改了a[0], 為什麼a裡的子列表全部都被修改了,接下來通過內建函式id來檢視一下a的子元素的記憶體地址(通過這個可以知道是否是同一個物件,id值相同,則為同一個物件)。

print id(a[0])
print id(a[1])
print id(a[2])
>>> 43106552
>>> 43106552
>>> 43106552

原來問題出在這裡,通過,a列表中的子元素統統指向同一個物件,不管修改其中的哪個子元素都會導致其它子元素跟著一起修改(當然前提是子元素都是可變元素,如果儲存的是字串等不可變元素就另當別論了)。

a = [1] * 3
print a
print id(a[0]), id(a[1]), id(a[2])
a[1] = 100
print a
print id(a[0]), id(a[1]), id(a[2])

# output
>>> [1, 1, 1]
>>> 35117232 35117232 35117232
>>> [1, 100, 1]
>>> 35117232 35118028 35117232

2.如何解決

可以通過列表推導解決上面的問題:

a = [[] for _ in range(3)]
print id(a[0]), id(a[1]), id(a[2])

#output
>>> 40111280 40111360 40111320