dict
鍵-值(key-value)存儲(chǔ),具有極快的查找速度。
d = {'Michael': 95, 'Bob': 75, 'Tracy': 85} \# 初始化
d['Michael']
結(jié)果是:95
改變某一個(gè)key的value方法:
d['Adam'] = 67
如果key不存在,dict就會(huì)報(bào)錯(cuò):
>>> d['Thomas']
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 'Thomas'
避免key不存在的錯(cuò)誤,有兩種辦法:
一是通過(guò)in判斷key是否存在:
'Thomas' in d
False
二是通過(guò)dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value:
>>> d.get('Thomas')
>>> d.get('Thomas', -1)
-1
注意:返回None的時(shí)候Python的交互式命令行不顯示結(jié)果。
要?jiǎng)h除一個(gè)key,用pop(key)方法,對(duì)應(yīng)的value也會(huì)從dict中刪除
>>> d.pop('Bob')
75
>>> d
{'Michael': 95, 'Tracy': 85}
dict內(nèi)部存放的順序和key放入的順序是沒(méi)有關(guān)系的。
需要牢記的第一條就是dict的key必須是不可變對(duì)象。
在Python中,字符串、整數(shù)等都是不可變的,因此,可以放心地作為key。而list是可變的,就不能作為key:
>>> key = [1, 2, 3]
>>> d[key] = 'a list'
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unhashable type: 'list'
set
set和dict類(lèi)似,也是一組key的集合,但不存儲(chǔ)value。由于key不能重復(fù),所以,在set中,沒(méi)有重復(fù)的key。
創(chuàng)建一個(gè)set,需要提供一個(gè)list作為輸入集合:
>>> s = set([1, 2, 3])
>>> s
{1, 2, 3}
傳入的參數(shù)[1, 2, 3]是一個(gè)list,而顯示的{1, 2, 3}只是告訴你這個(gè)set內(nèi)部有1,2,3這3個(gè)元素,顯示的順序也不表示set是有序的。
重復(fù)元素在set中自動(dòng)被過(guò)濾:
>>> s = set([1, 1, 2, 2, 3, 3])
>>> s
{1, 2, 3}
通過(guò)add(key)方法可以添加元素到set中,可以重復(fù)添加,但不會(huì)有效果:
>>> s.add(4)
>>> s
{1, 2, 3, 4}
>>> s.add(4)
>>> s
{1, 2, 3, 4}
通過(guò)remove(key)方法可以刪除元素:
>>> s.remove(4)
>>> s
{1, 2, 3}
set可以看成數(shù)學(xué)意義上的無(wú)序和無(wú)重復(fù)元素的集合,因此,兩個(gè)set可以做數(shù)學(xué)意義上的交集、并集等操作:
>>> s1 = set([1, 2, 3])
>>> s2 = set([2, 3, 4])
>>> s1 & s2
{2, 3}
>>> s1 | s2
{1, 2, 3, 4}
>>> a = 'abc'
>>> b = a.replace('a', 'A')
>>> b
'Abc'
>>> a
'abc'
對(duì)于不變對(duì)象來(lái)說(shuō),調(diào)用對(duì)象自身的任意方法,也不會(huì)改變?cè)搶?duì)象自身的內(nèi)容。相反,這些方法會(huì)創(chuàng)建新的對(duì)象并返回,這樣,就保證了不可變對(duì)象本身永遠(yuǎn)是不可變的。