Python入門 Dict和Set型別

2021-09-02 12:13:38 字數 3769 閱讀 4953

dict

dict表示「名字」-「成績」的查詢表如下:

d =
我們把名字稱為key,對應的成績稱為value,dict就是通過key來查詢value

花括號 {} 表示這是乙個dict,然後按照key: value, 寫出來即可。最後乙個 key: value 的逗號可以省略。

由於dict也是集合,len() 函式可以計算任意集合的大小:

>>> len(d)

3

可以簡單地使用 d[key] 的形式來查詢對應的 value,這和 list 很像,不同之處是,list 必須使用索引返回對應的元素,而dict使用key。

注意:通過 key 訪問 dict 的value,只要 key 存在,dict就返回對應的value。如果key不存在,會直接報錯:keyerror。

要避免 keyerror 發生,有兩個辦法:

一是先判斷一下 key 是否存在,用 in 操作符:

if 'paul' in d:

print d['paul']

如果 'paul' 不存在,if語句判斷為false,自然不會執行 print d['paul'] ,從而避免了錯誤。

二是使用dict本身提供的乙個 get 方法,在key不存在的時候,返回none:

>>> print d.get('bart')

59>>> print d.get('paul')

none

dict 的特點:

dict的第乙個特點是查詢速度快,無論dict有10個元素還是10萬個元素,查詢速度都一樣。而list的查詢速度隨著元素增加而逐漸下降。

不過dict的查詢速度快不是沒有代價的,dict的缺點是占用記憶體大,還會浪費很多內容,list正好相反,占用記憶體小,但是查詢速度慢。

dict的第二個特點就是儲存的key-value序對是沒有順序的!

dict的第三個特點是作為 key 的元素必須不可變,python的基本型別如字串、整數、浮點數都是不可變的,都可以作為 key。但是list是可變的,就不能作為 key。

修改dict

dict是可變的,也就是說,我們可以隨時往dict中新增新的 key-value。比如已有dict:

d =
要把新同學'paul'的成績 72 加進去,用賦值語句:

>>> d['paul'] = 72
再看看dict的內容:

>>> print d

如果 key 已經存在,則賦值會用新的 value 替換掉原來的 value:

>>> d['bart'] = 60

>>> print d

遍歷dict

直接使用for迴圈可以遍歷 dict 的 key:

>>> d = 

>>> for key in d:

... print key

set

dict的作用是建立一組 key 和一組 value 的對映關係,dict的key是不能重複的。

set 持有一系列元素,這一點和 list 很像,但是set的元素沒有重複,而且是無序的,這點和 dict 的 key很像。

建立 set 的方式是呼叫 set() 並傳入乙個 list,list的元素將作為set的元素:

>>> s = set(['a', 'b', 'c'])
可以檢視 set 的內容:

>>> print s

set(['a', 'c', 'b'])

請注意,上述列印的形式類似 list, 但它不是 list,仔細看還可以發現,列印的順序和原始 list的順序有可能是不同的,因為set內部儲存的元素是無序的。

因為set不能包含重複的元素,所以,當我們傳入包含重複元素的 list 會怎麼樣呢?

>>> s = set(['a', 'b', 'c', 'c'])

>>> print s

set(['a', 'c', 'b'])

>>> len(s)

3

結果顯示,set會自動去掉重複的元素

由於set儲存的是無序集合,所以我們沒法通過索引來訪問。

訪問 set中的某個元素實際上就是判斷乙個元素是否在set中。

bart是該班的同學嗎?

>>> 'bart' in s

true

set的特點:

set的內部結構和dict很像,唯一區別是不儲存value,因此,判斷乙個元素是否在set中速度很快。

set儲存的元素和dict的key類似,必須是不變物件,因此,任何可變物件是不能放入set中的。

最後,set儲存的元素也是沒有順序的。

遍歷set:

直接使用 for 迴圈可以遍歷 set 的元素:

>>> s = set(['adam', 'lisa', 'bart'])

>>> for name in s:

... print name

...

lisa

adam

bart

更新set:

由於set儲存的是一組不重複的無序元素,因此,更新set主要做兩件事:

一是把新的元素新增到set中,二是把已有元素從set中刪除。

新增元素時,用set的add()方法:

>>> s = set([1, 2, 3])

>>> s.add(4)

>>> print s

set([1, 2, 3, 4])

如果新增的元素已經存在於set中,add()不會報錯,但是不會加進去了:

>>> s = set([1, 2, 3])

>>> s.add(3)

>>> print s

set([1, 2, 3])

刪除set中的元素時,用set的remove()方法:

>>> s = set([1, 2, 3, 4])

>>> s.remove(4)

>>> print s

set([1, 2, 3])

如果刪除的元素不存在set中,remove()會報錯:

>>> s = set([1, 2, 3])

>>> s.remove(4)

traceback (most recent call last):

file "", line 1, in keyerror: 4

所以用add()可以直接新增,而remove()前需要判斷。

python基礎教程 dict和se

python內建字典 dict,全稱dictionary,在其他語言中稱為map,使用鍵值對儲存。ex d d xiaoli 95 直接定義鍵值對 ex d adm 67 d adm 67 判斷key是否存在 ex in 判斷 theme in d false get方法 d.get theme d...

自學python筆記5 使用dict和set

使用dict和set,使用dict比list查詢時間快,但是耗費空間記憶體 d print d print d maicael 把資料放入dict d halen 78 dict裡面可以新增新類容 print d d laizi 10 dict裡面value可變 print d print laiz...

python中dict和list排序

1 list排序 列表的排序是python內建功能,自身含有sort方法 如 s 2,1,3,0 s.sort 0,1,2,3 2 dict排序 對字典的排序,因為每乙個項包括乙個鍵值對,所以要選擇可比較的鍵或值進行排序 sorted iterable cmp key reverse cmp和key...