python之dict與set
阿新 • • 發佈:2018-04-18
python之dict與setdict全稱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