Python中dict的特點、更新dict、遍歷dict


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

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

由於dict是按 key 查找,所以,在一個dict中,key不能重復。

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

d = {
    'Adam': 95,
    'Lisa': 85,
    'Bart': 59
}

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

>>> print d
{'Lisa': 85, 'Adam': 95, 'Bart': 59}

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

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

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

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

{
    '123': [1, 2, 3],  # key 是 str,value是list
    123: '123',  # key 是 int,value 是 str ('a', 'b'): True # key 是 tuple,並且tuple的每個元素都是不可變對象,value是 boolean }

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

Python更新dict

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

d = {
    'Adam': 95,
    'Lisa': 85,
    'Bart': 59
}

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

>>> d['Paul'] = 72

再看看dict的內容:

>>> print d
{'Lisa': 85, 'Paul': 72, 'Adam': 95, 'Bart': 59}

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

>>> d['Bart'] = 60
>>> print d
{'Lisa': 85, 'Paul': 72, 'Adam': 95, 'Bart': 60}

任務

請根據Paul的成績 72 更新下面的dict:

d = {

    95: 'Adam',

    85: 'Lisa',

    59: 'Bart'

}

參考代碼:

d = {
    95: 'Adam',
    85: 'Lisa',
    59: 'Bart'
}
d[72]='paul'

 

 

Python之 遍歷dict

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

直接使用for循環可以遍歷 dict 的 key:

>>> d = { 'Adam': 95, 'Lisa': 85, 'Bart': 59 }
>>> for key in d:
...     print key
... 
Lisa
Adam
Bart

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

任務

請用 for 循環遍歷如下的dict,打印出 name: score 來。

d = {
    'Adam': 95,
    'Lisa': 85,
    'Bart': 59
}
參考代碼:
d = {
    'Adam': 95,
    'Lisa': 85,
    'Bart': 59
}
for key in d:
    print key + ':' ,d[key]


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM