1. 程式人生 > >set和dict理論和操作

set和dict理論和操作

() remove type [] erro append lis fromkeys mos

Set 集合 和 Dict字典
set 集合
collection 翻譯為集合類型,是一個大的概念 如:
set
是一個可變的,無序的,不重復的元素集合(已覆蓋的形式去除重復的元素)
s = set() 創建一個空set
s = set(iterable) 創建一個可叠代的集合
set的元素不可以索引
set可以叠代
set中的元素是可hash的元素,一般的可hash元素都是不可變類型數據
hash是將整個元素遍歷一遍,不管你是什麽類型,即使你是在元組中套了一個list 也不可以hash,
hash時會將復合類型裏面的元素全部遍歷一遍

>> s = {1,‘abd‘,(3,)}
>> s

{1, (3,), ‘abd‘}
>> s = {1,‘ac‘,(3,[4])}
Traceback (most recent call last):
File "<pyshell#53>", line 1, in <module>
s = {1,‘ac‘,(3,[4])}
TypeError: unhashable type: ‘list‘
>>
set 與 set 不能使用 +號 連接
set.add(元素) 一次只能添加一個元素,不能疊加 可叠代的對象;如果元素已經存在則什麽都不做
s = set()
>> s.add(range(6))
>> s
{range(0, 6)}
>>
update(others) >>> Neno 就地修改
多個可叠代對象 ;*+標識符(變量名),參數others必須是 可叠代對象
作用:將多個數據集合合並到一個set集合中;叠代時會自行去重
remove(elem)
從set中一出一個元素;元素不存在,拋出KeyError異常(類似字典)
discard(elem)
從set中移除一個元素;元素不存在什麽都不做
pop() >>>item
移除並返回任意元素;空集返回KeyError異常
clear()
移除所有元素
修改:
要麽刪除,要麽加入新的元素
查詢
非線性結構,無法索引
遍歷
可叠代所有元素
成員運算符
in 和 not in 判斷元素是否在set中
反復in 用set list 效率不高 耗時較長 不推薦使用in的類型之一

dict
定義:
初始化字典
d = {} 創建空字典
d = dict(**kwargs) 使用name = value 初始化一個字典
d = dict.fromkeys(iterable,value)
d = dict.fromkeys(range(6),6) 創建一個從零到5的key,值為6;不賦值時,默認為None

訪問字典
dict[key]
返回key對應的value值;當 key 不存在時拋出KeyError異常
dict.get(key[,default])
返回key對應的value值;key不存在時返回缺省值,如果沒有缺省值返回Neno
setdefault(key [,default])
返回key對應的value值;key不存在時,添加kv對,value的是為default,返回default
如果麽有default值就 缺省為Neno
字典的修改
dict [key] = value
將key對應的值進行修改,賦值
key不存在時 添加新的kv對
update([other])>>>>Neno 就地修改
使用另一個字典的kv對來更新本字典
key不存在時,就添加;存在,就覆蓋已經存在的值
字典的刪除
dict.pop(key [,default]) 移除的kv對是無序的
key存在就移除它,返回它的value
key不存在,返回給定的default;沒有設置default是,就拋出keyError異常

#我們直接移除時,會發生遍歷元素時 的key值 位移從而移除的元素會出現遺漏
#所以我們要建立一個新的列表,遍歷k將元素添加到其中,在實行pop()命令
不能在for循環中刪除,
d = dict(a=1,b=2,c="abc") 2018.08.14 53:00
keys=[]
for k,v in d.items():
if isinstance(v,int): #判斷 該值是否是 我們需要的值,
keys.append(k) #不是則將key 保存到一個list中

for k in keys: #遍歷keys中的k值 找到符合我們 if語句的V值
d.pop(k) #找到就將該元素從字典中移除
print(d)

dict.popitem()
移除並返回一個任意鍵值對
字典為empty,拋出KeyError異常
dict.clear()
清除字典
del 刪除 2018.08.14 13:00不清楚
刪除的並不是對象,而是將value的引用計數減一
字典的遍歷
字典是由鍵值對組成的元素集合,所以遍歷字典有三種形式
1.遍歷key
for key in dict.keys: print(key) == for k in dict: list(dict) == list(dict.keys())
2.遍歷value 2018.08.14 24:00 用其他遍歷value
for value in dict.values : print(value) for k in dict:print(dict[k])或者
3.遍歷kv值
for key,value in dict.items : print(kry,value) == list(dict.items())
總結
python3中,keys、value、items返回一個類似生成器的可叠代對象,不會吧函數的結果復制到內存中
dictionary view對象,可以使用len()、iter()封裝成叠代器的語句、in操作
字典的entry的動態視圖,針對items,鍵值對;字典發生變化,視圖將反映出這些變化
keys返回一個類set對象,也可以看做是一個set集合
keys values items python2 與 python3 有所不同 36:30
2018.08.14 33:00 不清楚
key的要求和set的元素是一致的
set的元素可以看做key,set可以看走dict的簡化版
hashsble可哈希才可以作為key,可用hash()測試
defaultdict缺省字典
collections.defaultdict([default_factory[,......]])
第一個參數default_factory,缺省為Neno,他提供一個初始化函數。當key不存在時,會調用這個工場函數來生成key對應的value

set和dict理論和操作