標籤:不可變類 可變 lex 賦值運算 不可變 改變 交集 記憶體位址 style
集合
集合是無序的,不重複的資料集合,它裡面的元素是可雜湊的(不可變類型),但是集合本身是不可雜湊(所以集合做不了字典的鍵)的。以下是集合最重要的兩點:
去重,把一個列表變成集合,就自動去重了。
關係測試,測試兩組資料之前的交集、差集、並集等關係。
# 集合裡面的元素是可雜湊的
# set1 = {‘1‘,‘alex‘,2,True,[1,2,3]} #報錯# set2 = {‘1‘,‘alex‘,2,True,{1:2}} #報錯# set3 = {‘1‘,‘alex‘,2,True,(1,2,[2,3,4])} #報錯
去重
# l= [1,1,2,2,3,4,5,5]# set1 = set(l)# print(set1,type(set1))# l = list(set1)# print(l,type(l))
集合的建立
# set1 = set({1,2,3,‘barry‘})# set2 = {1,2,‘barry‘}# print(set1,type(set1))# print(set2,type(set2))
增
# set1 = {‘alex‘,‘wusir‘,‘ritian‘,‘egon‘,‘barry‘}# set1.add(‘文文‘)# print(set1)# update:迭代著增加# set1.update(‘A‘)# print(set1)# set1.update(‘老師‘)# print(set1)# set1.update([1,2,3])# print(set1)
刪
# set = {‘alex‘,‘wusir‘,‘ritian‘,‘egon‘,‘barry‘}# set.remove(‘alex‘) #刪除一個元素# print(set)# pop隨機的刪除# set.pop() #隨機刪除一個元素# print(set)# clear清空# set.clear() #清空集合# print(set)# del# del set #刪除集合# print(set)
集合的其他動作
# 1.交集(& 或者 intersection)# set1 = {1,2,3,4,5}# set2 = {4,5,6,7,8}# print(set1&set2) #-->{4, 5}# print(set1.intersection(set2))# 2.並集(| 或者 union)# set1 = {1,2,3,4,5}# set2 = {4,5,6,7,8}# print(set1 | set2) #-->{1, 2, 3, 4, 5, 6, 7, 8}# print(set1.union(set2))#-->{1, 2, 3, 4, 5, 6, 7, 8}# 3.差集(- 或者 difference)# set1 = {1,2,3,4,5}# set2 = {4,5,6,7,8}# print(set1 - set2)# print(set1.difference(set2)) #-->{1, 2, 3}# 4.反交集(^ 或者 symmetric_difference)# set1 = {1,2,3,4,5}# set2 = {4,5,6,7,8}# print(set1 ^ set2) #-->{1, 2, 3, 6, 7, 8}# print(set1.symmetric_difference(set2))# 5子集與超集# set1 = {1,2,3}# set2 = {1,2,3,4,5,6}# print(set1 < set2)# print(set1.issubset(set2)) # 這兩個相同,都是說明set1是set2子集# print(set2 > set1)# print(set2.issuperset(set1)) # 這兩個相同,都是說明set2是set1超集。
frozenset不可變集合,讓集合變成不可變類型。
# s = frozenset(‘barry‘)# print(s,type(s)) # frozenset({‘a‘, ‘y‘, ‘b‘, ‘r‘}) <class ‘frozenset‘>
淺copy
# l1 = [1,2,3,[‘barry‘,‘alex‘]]# l2 = l1## l1[0] = 111# print(l1) # [111, 2, 3, [‘barry‘, ‘alex‘]]# print(l2) # [111, 2, 3, [‘barry‘, ‘alex‘]]# l1[3][0] = ‘wusir‘# print(l1) # [111, 2, 3, [‘wusir‘, ‘alex‘]]# print(l2) # [111, 2, 3, [‘wusir‘, ‘alex‘]]# print(id(l1),id(l2)) #--->對於賦值運算來說,l1與l2指向的是同一個記憶體位址,所以他們是完全一樣的。
# li = [1,2,3,[‘barry‘,‘alex‘]]
# l2 = li.copy()
# print(li,id(li))
# print(l2,id(l2))
# li[1] = 222
# print(li,id(li))
# print(l2,id(l2))
# li[3][0] = ‘wusir‘
# print(li,id(li[3]))
# print(l2,id(l2[3]))
# 對於淺copy來說,第一層建立的是新的記憶體位址,而從第二層開始,指向的都是同一個記憶體位址,
# 所以,對於第二層以及更深的層數來說,保持一致性
# 深拷貝deepcopy
# import copy# li = [1,2,3,[‘barry‘,‘alex‘]]# l2 = copy.deepcopy(li)# print(li,id(li))# print(l2,id(l2))## li[1] = 222# print(li,id(li))# print(l2,id(l2))## li[3][0] = ‘wusir‘# print(li,id(li[3]))# print(l2,id(l2[3]))# 對於深copy來說,兩個是完全對立的,改變 任意一個的任何元素(無論多少層),另一個絕對不改變
python-集合(set)