我們已經知道,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...