一 字典dict
1.定義
使用鍵-值(key-value)存儲,根據key算出value的存放位置(哈希函數),具有極快的查找速度。
dict內部存放的順序和key放入的順序無關,并且dict的key必須是不可變對象。
2.存入數據
1)初始化時存入
>>> d = {'Michael': 95, 'Bob': 75, 'Tracy': 85}>>> d['Michael']952)通過key放入
>>> d['Adam'] = 67>>> d['Adam']67一個key只能對應一個value。所以,多次對一個key放入value,后面的值會把前面的值沖掉:
>>> d['Jack'] = 90>>> d['Jack']90>>> d['Jack'] = 88>>> d['Jack']883.基本操作
1)檢查key是否存在
①通過in
②通過dict提供的get方法。如果key不存在,可以返回None,或者自己指定的value。返回None的時候Python的交互式命令行不顯示結果。
>>> d.get('Thomas')>>> d.get('Thomas', -1)-12)刪除key:使用pop(key)
方法,對應的value也會從dict中刪除。
4.與list相比,dict有以下幾個特點:
1)查找和插入的速度極快,不會隨著key的增加而增加
2)需要占用大量的內存,內存浪費多
而list相反:
1)查找和插入的時間隨著元素的增加而增加
2)占用空間小,浪費內存很少。
二 set
1.定義
set和dict類似,也是一組key的集合,但不存儲value。由于key不能重復,所以,在set中,沒有重復的key。
set和list一樣,key必須是不可變對象。
2.初始化
要創建一個set,需要提供一個list作為輸入集合:
>>> s = set([1, 2, 3])>>> sset([1, 2, 3])注意,傳入的參數[1, 2, 3]
是一個list,而顯示的set([1, 2, 3])
只是告訴你這個set內部有1,2,3這3個元素,顯示的[]
不表示這是一個list。
重復元素在set中自動被過濾:
>>> s = set([1, 1, 2, 2, 3, 3])>>> sset([1, 2, 3])2.基本操作
1)添加元素:add(key)
,可以重復添加但不會有效果。
2)刪除元素:remove(key)
3)并集和交集
set可以看成數學意義上的無序和無重復元素的集合,因此,兩個set可以做數學意義上的交集、并集等操作:
>>> s1 = set([1, 2, 3])>>> s2 = set([2, 3, 4])>>> s1 & s2set([2, 3])>>> s1 | s2set([1, 2, 3, 4])三 不可變對象
1.對于可變對象,比如list,對list進行操作,list內部的內容是會變化的,比如:
>>> a = ['c', 'b', 'a']>>> a.sort()>>> a['a', 'b', 'c']2.對于不可變對象,比如str,對str進行操作:
>>> a = 'abc'>>> b = a.replace('a', 'A')>>> b'Abc'>>> a'abc'要始終牢記的是,a
是變量,而'abc'
才是字符串對象。
有些時候,我們經常說,對象a
的內容是'abc'
。但其實是指,a
本身是一個變量,它指向的對象的內容才是'abc'
:
當我們調用a.replace('a', 'A')
時,實際上調用方法replace
是作用在字符串對象'abc'
上的。而這個方法雖然名字叫replace,但卻沒有改變字符串'abc'
的內容。相反,replace
方法創建了一個新字符串'Abc'
并返回。變量a
仍指向原有的字符串'abc'
,但變量b卻指向新字符串'Abc'
了:
所以,對于不變對象來說,調用對象自身的任意方法,也不會改變該對象自身的內容。相反,這些方法會創建新的對象并返回,這樣,就保證了不可變對象本身永遠是不可變的。
轉自http://www.liaoxuefeng.com/wiki/001374738125095c955c1e6d8bb493182103fac9270762a000/0013868193482529754158abf734c00bba97c87f89a263b000
新聞熱點
疑難解答