Python中最常見的數(shù)據(jù)結(jié)構(gòu):列表(list)和元組(tuple)。
列表和元組,都是一個可以放置任意數(shù)據(jù)類型的有序集合。二者對于數(shù)據(jù)類型沒有要求必須一致,示列如下所示
# 列表中同時包含int和string類型的元素
l = [1, 2, 'hello', 'world']
# 元組中同時含有int和string類型的元素
tup = ('jason', 22)
當(dāng)然也要明白它們是有區(qū)別的
- 列表是動態(tài)的,大小不固定,可以任意增加、刪除或者改變元素
- 元組是靜態(tài)的,大小是固定的,無法增加刪除或者改變
下面的一個簡單示列可以讓我們理解更加深入。
l = [1, 2, 3, 4]
l[3] = 40
l
[1, 2, 3, 40]
tup = (1, 2, 3, 4)
tup[3] = 40
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'tuple' object does not support item assignment
列表和元組的基本操作
tup = (1, 2, 3, 4)
# 創(chuàng)建新的元組new_tup,并依次填充原元組的值
new_tup = tup + (5, )
l = [1, 2, 3, 4]
# 添加元素5到原列表的末尾
l.append(5)
list = [1, 2, 3, 4]
# 返回列表中索引從1到2的子列表
l[1:3]
[2, 3]
tup = (1, 2, 3 , 4)
返回元組中索引從1到2的子元組
tup[1:3]
(2, 3)
#列表的每一個元素也是一個列表
l = [[1, 2, 3], [4, 5]]
# 元組中每個元素也是一個元組
tup = ((1, 2, 3), (4, 5, 6))
元組和列表可以通過list()和tuple()函數(shù)互相轉(zhuǎn)換
list((1, 2, 3, 4 ))
[1, 2, 3, 4]
tuple([1, 2, 3, 4])
(1, 2, 3, 4)
#常見的一些內(nèi)置函數(shù)
l = [3, 2, 3, 7 ,8, 1]
l.count(3)
2
l.index(7)
3
l.reverse()
l
[1, 8, 7, 3, 2 , 3]
l.sort()
l
[1, 2, 3, 3, 7, 8]
tup = (3, 2, 3, 7, 8, 1)
tup.count(3)
2
tup.index(7)
3
list(reversed(tup))
[1, 8, 7, 3, 2, 3]
sorted(tup)
[1, 2, 3, 3, 7, 8]
- count(item) 表示統(tǒng)計列表/元組中item出現(xiàn)的次數(shù)
- index(item)表示返回列表/元組中item第一次出現(xiàn)的索引
- list.reverse()和list.sort()分別表示原地倒轉(zhuǎn)列表和排序
reversed()和sorted()同樣表示對列表/元組進行倒轉(zhuǎn)和排序,但是會返回一個倒轉(zhuǎn)以后或者排序好的新的列表/元組
列表和元組的差異
列表是動態(tài)的,可變的;元組是靜態(tài)的,不可變的。二者存在的差異,對它們各自的存儲是有影響的,可以看下面的列子
>>> l = [1,2,3]
>>> l.__sizeof__()
64
>>> tup = (1,2,3)
>>> tup.__sizeof__()
48
上面的例子列表和元組都是存儲了相同的元素,但是是用的空間是不一樣的。列表因為是動態(tài)的,它需要存儲指針來指向?qū)?yīng)的元素。同時,列表是可變的,這就需要分配額外的存儲分配的長度大小,這樣就可以及時追蹤列表空間使用情況,當(dāng)空間不足時及時分配額外的存儲空間。下面的列子就可以很好地說明問題
>>> l = []
>>> l.__sizeof__()
40
>>> l.append(1)
>>> l.__sizeof__()
72
>>> l.append(2)
>>> l.__sizeof__()
72
>>> l.append(3)
>>> l.__sizeof__()
72
>>> l.append(4)
>>> l.__sizeof__()
72
>>> l.append(5)
>>> l.__sizeof__()
104
列表和元組的使用場景
如果存儲數(shù)據(jù)和數(shù)量不變,首選元組;
如果存儲數(shù)據(jù)或者數(shù)量是可變的,那么選擇列表更加合適