上期編程題的答案如上圖。
列表(list)
list是一種有序的集合,可以隨時(shí)添加和刪除其中的元素。
當(dāng)索引超出了范圍時(shí),Python會(huì)報(bào)一個(gè)IndexError錯(cuò)誤,所以,要確保索引不要越界,記得最后一個(gè)元素的索引是len(classmates) - 1。如果要取最后一個(gè)元素,除了計(jì)算索引位置外,還可以用-1做索引,直接獲取最后一個(gè)元素。
以此類(lèi)推,可以獲取倒數(shù)第2個(gè)、倒數(shù)第3個(gè),當(dāng)然,倒數(shù)第4個(gè)就越界了。
list是一個(gè)可變的有序表,所以,可以往list中append元素到末尾,也可以把元素insert到指定的位置,比如索引號(hào)為1的位置.但是要注意insert方法不同于append方法,insert需要傳2個(gè)參數(shù),第一個(gè)參數(shù)為插入的位置,插在第一個(gè)傳0,依次類(lèi)推。
要?jiǎng)h除list末尾的元素,用pop()方法;要?jiǎng)h除指定位置的元素,用pop(i)方法,其中i是索引位置。
要把某個(gè)元素替換成別的元素,可以直接賦值給對(duì)應(yīng)的索引位置;
list里面的元素的數(shù)據(jù)類(lèi)型也可以不同,比如:
L = ['Apple', 123, True]
list元素也可以是另一個(gè)list,比如:
s = ['python', 'java', ['asp', 'php'], 'scheme']
len(s)
4
要注意s只有4個(gè)元素,其中s[2]又是一個(gè)list
如果拆開(kāi)寫(xiě)就更容易理解了:
p = ['asp', 'php']
s = ['python', 'java', p, 'scheme']
要拿到'php'可以寫(xiě)p[1]或者s[2][1],因此s可以看成是一個(gè)二維數(shù)組,類(lèi)似的還有三維、四維……數(shù)組,不過(guò)很少用到。
如果一個(gè)list中一個(gè)元素也沒(méi)有,就是一個(gè)空的list,它的長(zhǎng)度為0:
L = []
len(L)
0
好了,列表就講到這里了,你學(xué)會(huì)了嗎?
下期我們講解元祖(tuple),敬請(qǐng)期待!