標籤:方法 效果 告訴 集合 注意 val rem 兩種 操作
dict(字典):用空間換取時間,佔據空間大,但查詢速度快,索引值對(key:value),key唯一
d = {‘Michael‘: 95, ‘Bob‘: 75, ‘Tracy‘: 85}
由於一個key只能對應一個value,所以,多次對一個key放入value,後面的值會把前面的值衝掉:
>>> d[‘Jack‘] = 90>>> d[‘Jack‘]90>>> d[‘Jack‘] = 88>>> d[‘Jack‘]88
要避免key不存在的錯誤,有兩種辦法,一是通過in判斷key是否存在:
>>> ‘Thomas‘ in dFalse
二是通過dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value:
>>> d.get(‘Thomas‘)>>> d.get(‘Thomas‘, -1)-1
要刪除一個key,用pop(key)方法,對應的value也會從dict中刪除:
>>> d.pop(‘Bob‘)75>>> d{‘Michael‘: 95, ‘Tracy‘: 85}
請務必注意,dict內部存放的順序和key放入的順序是沒有關係的。
set:
set和dict類似,也是一組key的集合,但不儲存value。由於key不能重複,所以,在set中,沒有重複的key。
要建立一個set,需要提供一個序列(list、string)作為輸入集合:
>>> s = set([1, 2, 3])>>> s{1, 2, 3}
注意,傳入的參數[1, 2, 3]是一個list,而顯示的{1, 2, 3}只是告訴你這個set內部有1,2,3這3個元素,顯示的順序也不表示set是有序的。。
重複元素在set中自動被過濾:
>>> s = set([1, 1, 2, 2, 3, 3])>>> s{1, 2, 3}
通過add(key)方法可以添加元素到set中,可以重複添加,但不會有效果:
>>> s.add(4)>>> s{1, 2, 3, 4}>>> s.add(4)>>> s{1, 2, 3, 4}
通過remove(key)方法可以刪除元素:
>>> s.remove(4)>>> s{1, 2, 3}
set可以看成數學意義上的無序和無重複元素的集合,因此,兩個set可以做數學意義上的交集、並集、差集等操作:
>>> s1 = set([1, 2, 3])>>> s2 = set([2, 3, 4])>>> s1 & s2{2, 3}>>> s1 | s2{1, 2, 3, 4}
>>> s1 - s2{1}
可以通過list()方法將通過set處理過的列表元素轉換成列表的形式:
>>>a = list(set([1,2,3,4]))
>>> a
[1,2,3,4]
set和dict的唯一區別僅在於沒有儲存對應的value,但是,set的原理和dict一樣,所以,同樣不可以放入可變對象,因為無法判斷兩個可變對象是否相等,也就無法保證set內部“不會有重複元素”。
dict與set -- Python