慕課網《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()前需要判斷。