1. 程式人生 > >python之dict與set

python之dict與set

python之dict與set

dict全稱dictionary,使用鍵-值(key-value)存儲,書寫一個dict

name={:::}
(name[])

當數據量大時,字典比列表和元組速度快

dict實現原理和查字典是一樣的,假設字典包含一萬字,list查詢方法是一個一個查找,知道找到為止,dict是查這個字對應的頁碼,然後直接找到該頁。


第二種方式書寫字典

name['xy']=24


調用與更新。

name['xy']

name['xy']=55

name['xy']

如果鍵不存在,會報異常

>>> name['sss']

Traceback (most recent call last):

File "<pyshell#22>", line 1, in <module>

name['sss']

KeyError: 'sss'


要避免key不存在的錯誤,有兩種辦法,一是通過in判斷key是否存在,

技術分享圖片

二是通過dict提供的get()方法,如果key不存在,可以返回None(交互模式不返回),或者自己指定的value

技術分享圖片


dict刪除pop()

技術分享圖片

dict和list與tuple的優缺點

dict查詢速度快,占用大量內存,list與tuple查詢速度慢,占用內存小

dict的keys是不可變的,因此list不能作為dict的key



set

set與dict類似,也是一組key的集合,但是不存儲value,由於key不能重復,所以,在set中,沒有重復的key,(無順序的)

要創建一個set,需要提供一個list作為輸入集合

技術分享圖片

通過add(key)方法可以添加元素到set中,可以重復添加,但不會有效果

技術分享圖片

通過remove(key)方法可以刪除元素

技術分享圖片

set可以看成數學意義上的無序和無重復元素的集合,因此,兩個set可以做數學意義上的交際,並集等操作:

技術分享圖片


str.replace()替換等於重新賦值,list.sort()排序


python之dict與set