字典(dictionary)
字典在某些語言中可能稱為 聯(lián)合內(nèi)存 (associative memories) 或 聯(lián)合數(shù)組 (associative arrays)衩婚。序列是以連續(xù)的整數(shù)為索引,與此不同的是效斑,字典以"關(guān)鍵字"為索引,關(guān)鍵字可以是任意不可變類型柱徙,通常用字符串或數(shù)值缓屠。如果元組中只包含字符串和數(shù)字,它可以作為關(guān)鍵字护侮,如果它直接或間接地包含了可變對象敌完,就不能當(dāng)做關(guān)鍵字。不能用列表做關(guān)鍵字羊初,因?yàn)榱斜砜梢杂盟饕醺取⑶懈罨蛘?append() 和 extend() 等方法改變。
字典是無序的鍵:值對 (key:value 對)集合长赞,鍵必須是互不相同的(在同一個(gè)字典之內(nèi))晦攒。使用大括號創(chuàng)建一個(gè)空的字典:{}。初始化列表時(shí)得哆,在大括號內(nèi)放置一組逗號分隔的鍵:值對脯颜,這也是字典輸出的方式。
字典的主要操作是依據(jù)鍵來存儲和取值贩据。也可以用 del 來刪除鍵:值對(key:value)栋操,從一個(gè)不存在的鍵中取值會導(dǎo)致錯(cuò)誤闸餐。
常見字典操作方法
D.clear()刪除字典內(nèi)所有元素
D.copy()返回一個(gè)字典的復(fù)制
D.fromkeys(seq,val)創(chuàng)建一個(gè)新字典,以序列seq中元素做字典的鍵矾芙,val為字典所有鍵對應(yīng)的初始值
D.get(key, default=None)返回指定鍵的值舍沙,如果值不在字典中返回default值
D.has_key(key)如果鍵在字典dict里返回true,否則返回false
D.items()以列表返回可遍歷的(鍵, 值) 元組數(shù)組
D.keys()以列表返回一個(gè)字典所有的鍵
D.setdefault(key, default=None)和get()類似, 但如果鍵不存在于字典中剔宪,將會添加鍵并將值設(shè)為default
D.update(dict2)把字典dict2的鍵/值對更新到dict里
D.values()以列表返回字典中的所有值
D.pop(key)刪除一個(gè)鍵并返回它的值拂铡,類似于列表的pop,只不過刪除的是一個(gè)鍵不是一個(gè)可選的位置
del D[key]刪除鍵
D[key] = 42新增或修改鍵
字典用法注意事項(xiàng):
序列運(yùn)算無效,字典元素間是沒有順序的概念
對新索引賦值會添加項(xiàng)
鍵不一定總是字符串
元祖(tuple)
tuple是另一種有序的數(shù)據(jù)類型歼跟,與list比較類似和媳。主要不同的一點(diǎn)是tuple被創(chuàng)建后就不能對其進(jìn)行修改。所以哈街,tuple與list不同留瞳,沒有append(),pop(),insert()這些方法可以使用。獲取元素的方法和list是一樣的骚秦,可以通過索引來訪問(也是從0開始的)她倘,只不過不能賦值成為其他的元素。
因?yàn)閠uple不可變作箍,所以代碼更安全硬梁。如果可以的話,我們盡量使用tuple代替list胞得。
創(chuàng)造元組
定義一個(gè)空的tuple荧止,使用():
只有1個(gè)元素的元組在進(jìn)行定義的時(shí)候,需要加一個(gè)逗號,來消除歧義阶剑,否則定義的就不是一個(gè)元組而是元素本身:
Python 的元組數(shù)據(jù)類型包含更多的方法跃巡。
tup.index(x, [start, [stop]])) 返回元組中start到stop索引中第一個(gè)值為 x 的元素在整個(gè)列表中的索引。如果沒有匹配的元素就會返回一個(gè)錯(cuò)誤牧愁。
tup.count(x) 返回 x 在元組中出現(xiàn)的次數(shù)素邪。
cmp(tuple1, tuple2) 比較元組中兩個(gè)元素。
len(tuple) 計(jì)算元組元素個(gè)數(shù)猪半。
max(tuple) 返回元組中元素最大值兔朦。
min(tuple) 返回元組中元素最小值。
tuple(seq) 將列表轉(zhuǎn)換為元組磨确。
元組不提供字符串沽甥、列表和字典中的方法。如果相對元組排序乏奥,通常先得將它轉(zhuǎn)換為列表并使其成為一個(gè)可變對象安接,才能獲得使用排序方法,或使用sorted內(nèi)置方法。
集合(set)
與dict類似盏檐,set也是一組key的集合歇式,但不存儲value。由于key不能重復(fù)胡野,所以材失,在set中,沒有重復(fù)的key硫豆。創(chuàng)建一個(gè)set龙巨,需要提供一個(gè)list作為輸入集合:
由于set是無序和無重復(fù)元素的集合,所以兩個(gè)set可以坐數(shù)學(xué)意義上的交并集等操作
與dict一樣熊响,set同樣不可以放入可變對象旨别,因?yàn)闊o法判斷兩個(gè)可變對象是否相等,也就無法保證set內(nèi)部不會有重復(fù)元素汗茄。所以把list放入set秸弛,會報(bào)錯(cuò)。