Python基礎篇之dict

2021-08-11 21:05:55 字數 2552 閱讀 3825

我們已經知道,list 和 tuple 可以用來表示順序集合,例如,班裡同學的名字:

[『adam』, 『lisa』, 『bart』]

或者考試的成績列表:

[95, 85, 59]

但是,要根據名字找到對應的成績,用兩個 list 表示就不方便。

如果把名字和分數關聯起來,組成類似的查詢表:

『adam』 ==> 95

『lisa』 ==> 85

『bart』 ==> 59

給定乙個名字,就可以直接查到分數。

python的 dict 就是專門幹這件事的。用 dict 表示「名字」-「成績」的查詢表如下:

d =

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

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

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

len(d)

3 注意: 乙個 key-value 算乙個,因此,dict大小為3。

我們已經能建立乙個dict,用於表示名字和成績的對應關係:

d =

那麼,如何根據名字來查詢對應的成績呢?

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

print d[『adam』]

95 print d[『paul』]

traceback (most recent call last):

file 「index.py」, line 11, in

print d[『paul』]

keyerror: 『paul』

注意: 通過 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有10個元素還是10萬個元素,查詢速度都一樣。而list的查詢速度隨著元素增加而逐漸下降。

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

由於dict是按 key 查詢,所以,在乙個dict中,key不能重複。

dict的第二個特點就是儲存的key-value序對是沒有順序的!這和list不一樣:

d =

當我們試圖列印這個dict時:

print d

列印的順序不一定是我們建立時的順序,而且,不同的機器列印的順序都可能不同,這說明dict內部是無序的,不能用dict儲存有序的集合。

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

可以試試用list作為key時會報什麼樣的錯誤。

不可變這個限制僅作用於key,value是否可變無所謂:

最常用的key還是字串,因為用起來最方便。

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

d =

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

d[『paul』] = 72

再看看dict的內容:

print d

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

d[『bart』] = 60

print d

由於dict也是乙個集合,所以,遍歷dict和遍歷list類似,都可以通過 for 迴圈實現。

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

d =

for key in d:

… print key

… lisa

adam

bart

由於通過 key 可以獲取對應的 value,因此,在迴圈體內,可以獲取到value的值。

Python基礎之字典dict

字典的特性,鍵值對出現 字典的定義 字典的key不可重複,如果key重複的話,預設最後乙個元素新增到字典中,多個元素之間用逗號分割。字典是無序的 定義乙個字典 例 dic 字典的常用方法 fromkeys 引數是乙個可迭代型別,把每乙個迭代物件變成字典的key,value預設為none 可以修改 例...

python基礎之字典 dict

字典 dict 是一種key value 字典是無序的,不能像str list 一樣 通過index查詢資料 字典內可以迴圈巢狀list dict等 列表key是唯一的,值不限制 學號 姓名 info 新增 修改 info 004 1 查詢print info.get 001 通過key獲取valu...

Python基礎之 字典dict

1.collections模組 collections模組包含除了dict set list tuple以外的一些特殊的容器型別,比如下面幾個 1 ordereddict類 排序字典,是字典的子類。2 defaultdict 使用工廠函式建立字典,使不用考慮缺失的字典鍵。3 counter類 為ha...