Python 06_Dict 和 Set 類(lèi)型

01 什么是 dict

一個(gè)花括號(hào) {} 就表示一個(gè) dict,然后按照 key: value 這樣的形式, 寫(xiě)出來(lái)即可。最后一個(gè)成員后面的逗號(hào)可以省略。 由于 dict 也是集合, len() 函數(shù)可以計(jì)算任意集合的大?。?/p>

>>> len(d)

就可以打印出該集合的大小。例如一個(gè) dict,

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

打印這個(gè)集合的大小就為 3 。

02 訪問(wèn) dict

如果需要訪問(wèn) dict 里面的 value, 那么就需要通過(guò) key 來(lái)訪問(wèn),只要 key 存在, dict 就返回對(duì)應(yīng)的 value, 如果 key 不存在,會(huì)直接報(bào)錯(cuò), KeyError。
為了避免 KeyError 發(fā)生:

  • 可以先判斷一下 Key 是否存在,用 in 操作符,
if 'Adam' in d:
     print d['Adam']

不存在自然不會(huì)執(zhí)行,從而避免了錯(cuò)誤。

  • 使用 dict 本身提供的一個(gè) get 方法,
>>> print d.get('Bart')
59
>>> print d.get('Paul')
None

在 key 不存在的時(shí)候,返回一個(gè) None。

03 dict 的特點(diǎn)

  • dict 的第一個(gè)特點(diǎn)是查找速度快, 無(wú)論多少個(gè)元素查找速度都是一樣的,而 list 的查找速度會(huì)隨著元素的增加而下降。 dict 查找速度快的缺點(diǎn)就是占用內(nèi)存大,還會(huì)浪費(fèi)很多內(nèi)容, list 恰恰相反。
    dict 是按照 key 查找的, 所以,在一個(gè) dict 中, key 不能重復(fù)。
  • dict 的第二個(gè)特點(diǎn)就是 儲(chǔ)存的 key-value 序列是沒(méi)有順序的! 和 list 不一樣。不能用 dict 儲(chǔ)存有序的集合
  • dict 的第三個(gè)特點(diǎn)是作為 key 的元素必須不可變, Python 的基本類(lèi)型如 字符串、整數(shù)、浮點(diǎn)數(shù)、都是不可變的, 都可以作為 key ,而 list 是可變的,不能作為 key 。(跟 C 中的 switch case 有點(diǎn)類(lèi)似)。

04 更新 dict

例如

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

要把 'Paul' 的成績(jī) 72 添加進(jìn)去, 使用賦值語(yǔ)句:

d[72] = 'Paul'
print(d)

05 遍歷 dict

dict 也是集合, 那么遍歷 dict 和遍歷 list 類(lèi)似, 也可以使用 for 循環(huán)實(shí)現(xiàn)。
使用 for 循環(huán)遍歷 dict 打印出 名字:分?jǐn)?shù):

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

06 什么是 set

set 持有一系列元素,這一點(diǎn)和 list 很像,但是 set 的元素沒(méi)有重復(fù),而且是無(wú)序的,這點(diǎn)和 dict 的 key 很像。
創(chuàng)建 set 的方式是調(diào)用 set() 并傳入一個(gè) list, list 的元素將作為 set 的元素:

s = set(['A','B','C'])

有點(diǎn)類(lèi)似 list, 但它不是 list 。 set 不能包含重復(fù)的元素, 當(dāng)我們傳入相同的元素時(shí), set 會(huì)自動(dòng)去掉重復(fù)的元素。

>>>s = set(['A','B','C','C'])
>>>print s
set(['A','B','C'])
>>>len(s)
3

07 訪問(wèn) set

set 儲(chǔ)存無(wú)序集合, 則無(wú)法通過(guò)索引來(lái)訪問(wèn), 訪問(wèn) set 中的某個(gè)元素就是判斷這個(gè)元素是否在 set 中。如:

s = set(['adam','bart'])
print 'adam' in s
print 'bart' in s  

注意區(qū)分大?。? Adam 和 adam 在 set 中屬于不同的元素。

08 set 的特點(diǎn)

  • set 的內(nèi)部結(jié)構(gòu)和 dict 很像,唯一區(qū)別是不存儲(chǔ) value,因此,判斷一個(gè)元素是否在 set 中速度很快。

  • set 存儲(chǔ)的元素和 dict 的 key 類(lèi)似,必須是不變對(duì)象,因此,任何可變對(duì)象是不能放入 set 中的。

  • set 存儲(chǔ)的元素也是沒(méi)有順序的

09 遍歷 set

可使用 for 遍歷 set

>>> s = set(['Adam', 'Lisa', 'Bart'])
>>> for name in s:
>>> print name

Lisa
Adam
Bart

10 更新 set

由于 set 儲(chǔ)存的是不重復(fù)的無(wú)序元素, 更新 set 主要做兩件事:

  • 把新元素添加到 set 中
  • 把已經(jīng)有的元素從 set 中刪除
    添加元素, 用 set 的 add() 方法; 刪除 set 中的元素, 用 set 中的 remove() 方法。
    例如:
>>> s = set([1,2,3])
>>> s.add(4)
>>> print  s
set([1,2,3,4])

刪除也類(lèi)似, 但需要注意的是如果刪除的元素不在 set 中, remove() 則會(huì)報(bào)錯(cuò)。
所以使用 add() 可以直接添加, 而 remove() 前需要判斷。

  • 練習(xí)
    針對(duì)下面的 set,給定一個(gè) list,對(duì) list 中的每一個(gè)元素,如果在 set 中,就將其刪除,如果不在 set 中,就添加進(jìn)去。

s = set(['Adam', 'Lisa', 'Paul'])
L = ['Adam', 'Lisa', 'Bart', 'Paul']

s = set(['Adam', 'Lisa', 'Paul'])
L = ['Adam', 'Lisa', 'Bart', 'Paul']
for name in L:
    if name in s:
        s.remove(name)
    else:
        s.add(name)
print s
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容