Python--關於set

Pyerlife發表於2016-06-29

慕課網《Pyrhon入門》學習筆記

 

1、set 特性

set 持有一系列元素,這一點和 list 很像,但是set的元素沒有重複,而且是無序的,這點和 dict 的 key很像。

可以將set 視作不帶value 的 dict 中的key , 因此判斷一個元素是否在set中速度很快

set儲存的元素和dict的key類似,必須是不變物件,因此,任何可變物件是不能放入set中的。

建立 set 的方式是呼叫 set() 並傳入一個 list,list的元素將作為set的元素:

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

可以檢視 set 的內容:

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

請注意,上述列印的形式類似 list, 但它不是 list,仔細看還可以發現,列印的順序和原始 list 的順序有可能是不同的,因為set內部儲存的元素是無序的。

因為set不能包含重複的元素,所以,當我們傳入包含重複元素的 list 會怎麼樣呢?

 >>> s = set(['A', 'B', 'C', 'C'])
 >>> print s
 set(['A', 'C', 'B'])
 >>> len(s)
 3
 結果顯示,set會自動去掉重複的元素,原來的list有4個元素,但set只有3個元素。
 2、訪問set 
 由於set儲存的是無序集合,所以沒法通過索引來訪問。
 訪問 set中的某個元素實際上就是判斷一個元素是否在set中。
 例如,儲存了班裡同學名字的set:
 >>> s = set(['Adam', 'Lisa', 'Bart', 'Paul'])
 可以用 in 操作符判斷:
 Bart是該班的同學嗎?
 >>> 'Bart' in s
 True
 Bill是該班的同學嗎?
 >>> 'Bill' in s
 False
 3、set的應用舉例 
 假設我們讓使用者輸入星期一至星期日的某天,如何判斷使用者的輸入是否是一個有效的星期呢? 
 如果事先建立好一個set,包含'MON' ~ 'SUN':
 weekdays = set(['MON', 'TUE', 'WED', 'THU', 'FRI', 'SAT', 'SUN'])
 再判斷輸入是否有效,只需要判斷該字串是否在set中:
 x = '???' # 使用者輸入的字串 
 if x in weekdays: 
 print 'input ok' 
 else: 
 print 'input error' 
 4、遍歷set 
 
由於 set 也是一個集合,所以,遍歷 set 和遍歷 list 類似,都可以通過 for 迴圈實現。
直接使用 for 迴圈可以遍歷 set 的元素:
 >>> s = set(['Adam', 'Lisa', 'Bart'])
 >>> for name in s: 
 ... print name 
 ...  
 Lisa 
 Adam 
 Bart 

注意: 觀察 for 迴圈在遍歷set時,元素的順序和list的順序很可能是不同的.
 5、更新set 
 
由於set儲存的是一組不重複的無序元素,因此,更新set主要做兩件事:
一是把新的元素新增到set中,二是把已有元素從set中刪除。
新增元素時,用set的add()方法:
 >>> s = set([1, 2, 3])
 >>> s.add(4)
 >>> print s
 set([1, 2, 3, 4])

如果新增的元素已經存在於set中,add()不會報錯,但是不會加進去了:
 >>> s = set([1, 2, 3])
 >>> s.add(3)
 >>> print s
 set([1, 2, 3])

刪除set中的元素時,用set的remove()方法:
 >>> s = set([1, 2, 3, 4])
 >>> s.remove(4)
 >>> print s
 set([1, 2, 3])

如果刪除的元素不存在set中,remove()會報錯:
 >>> s = set([1, 2, 3])
 >>> s.remove(4)
 Traceback (most recent call last):
 File "", line 1, in
 KeyError: 4

所以用add()可以直接新增,而remove()前需要判斷

相關文章