dict
python內建了字典: dict支援,dict 全稱dictionary,在其他語言也成為map, 使用見-值儲存,具有極快的查詢速度.
格式:
>>> d =
而訪問字典時,只需要鍵就能找到對應的值, 如輸入d[『winddy』],則會輸入99.
如果key不村子,dict就會報錯
>>> d['hh']
traceback (most recent call last):
file
"", line 1, in
keyerror
:'hh'
要避免key不存在的錯誤,有兩種方法
- 通過 in 判斷 key 是否存在:
```
>>> 'hh' in d
false
```
- 通過dict提供的get方法,如果 key 不存在, 可以返回none, 或則自己指定的 value
>>> d.get('hh')
>>> d.get('hh',-1)
-1
要刪除乙個 key, 用 pop(key)方法, 對應的value也會從dict中刪除
注意, dict 內部存放的順序和key放入的順序是沒有關係的
和list比較, dict有以下幾個特點:
- 查詢和插入的速度極快,不會隨著key的增加而增加
- 需要占用大量的記憶體,記憶體浪費多
而list相反
- 查詢和插入的時間隨著元素的增加而增加
- 占用空間小,浪費記憶體很少.
set
set和dict類似,也是一組key的集合,但不儲存value。由於key不能重複,所以,在set中,沒有重複的key。
要建立乙個set,需要提供乙個list作為輸入集合:
>>> s = set([1, 2, 3])
>>> s
set([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])
>>> s
set([1, 2, 3])
通過add(key)方法可以新增元素到set中,可以重複新增,但不會有效果:
>>> s.add(4)
>>> s
set([1, 2, 3, 4])
>>> s.add(4)
>>> s
set([1, 2, 3, 4])
通過remove(key)方法可以刪除元素:
>>> s.remove(4)
>>> s
set([1, 2, 3])
set可以看成數學意義上的無序和無重複元素的集合,因此,兩個set可以做數學意義上的交集、並集等操作:
>>> s1 = set([1, 2, 3])
>>> s2 = set([2, 3, 4])
>>> s1 & s2
set([2, 3])
>>> s1 | s2
set([1, 2, 3, 4])
set和dict的唯一區別僅在於沒有儲存對應的value,但是,set的原理和dict一樣,所以,同樣不可以放入可變物件,因為無法判斷兩個可變物件是否相等,也就無法保證set內部「不會有重複元素」。試試把list放入set,看看是否會報錯。 python學習筆記 dict
1.往dict中動態加入元素 dict dict item i 2.dict內建函式與方法 序號函式及描述 1cmp dict1,dict2 比較兩個字典元素。2len dict 計算字典元素個數,即鍵的總數。3str dict 輸出字典可列印的字串表示。4type variable 返回輸入的變數...
python之dict學習筆記之二
一 遍歷 字典的遍歷方法很多 1.直接利用dict d for i in d print i,d i a aa c cc b bb 2.利用 items for i,v in d.items print i,v a aa c cc b bb當然也可以這樣 for i,v in d.items pri...
python學習之dict簡介
3.字典 dict 特點 無序性 沒有索引 可變的資料型別 值可變 鍵不可變 字典的結構 鍵值對組合 key value對 鍵 key 唯一性 不可重複 不可變的資料型別 list等不能作為鍵 值 value 注意事項 演示dict的特點以及使用場景 dic1 print dic1,type dic...