python set(集合)


集合是無序的,不重復的數據集合,它里面的元素是可哈希的(不可變類型),但是集合本身是不可哈希(所以集合做不了字典的鍵)的。以下是集合最重要的兩點:

  去重,把一個列表變成集合,就自動去重了。

  關系測試,測試兩組數據之前的交集、差集、並集等關系。

1.集合的創建

set1 = set({1, 2, 'barry'})
set2 = {1, 2, 'barry'}
print(set1, set2)  # {1, 2, 'barry'} {1, 2, 'barry'}

2.集合的增

  ① add

  ② upadte

set1 = {'alex', 'zzl',  'barry'}

# add
set1.add('zhuge')
print(set1)  # {'alex', 'zzl',  'barry', 'zhuge'}

# update  迭代增加
set1.update('zhuge')
print(set1)  # {'e', 'zzl', 'alex', 'h', 'g', 'z', 'barry', 'u'}

3.集合的刪

  ① remove 刪除指定元素,無該元素則報錯

  ② pop 隨機刪除一個元素,有返回值

   ③ clear 清空

  ④ del 刪除

set1 = {'alex', 'zzl',  'barry'}

# remove  刪除指定元素,無該元素則報錯
set1.remove('zzl')
print(set1)  # {'alex', 'barry'}

# pop 隨機刪除一個元素,有返回值
print(set1.pop())  # barry
print(set1)        # {'alex', 'zzl'}

# clear 清空
set1.clear()
print(set1)  # set()

# del 刪除
del set1
print(set1)  # 報錯

4.集合的其他操作

  4.1 交集。(&  或者 intersection)

set1 = {1, 2, 3, 4, 5}
set2 = {4, 5, 6, 7, 8}
print(set1 & set2)  # {4, 5}
print(set1.intersection(set2))  # {4, 5}

  4.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(set2.union(set1))  # {1, 2, 3, 4, 5, 6, 7,8}

  4.3 差集。(- 或者 difference)

set1 = {1, 2, 3, 4, 5}
set2 = {4, 5, 6, 7, 8}
print(set1 - set2)  # {1, 2, 3}
print(set1.difference(set2))  # {1, 2, 3}

  4.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))  # {1, 2, 3, 6, 7, 8}

  4.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超集。

5,frozenset不可變集合,讓集合變成不可變類型。

s = frozenset('barry')
print(s, type(s))  # frozenset({'a', 'y', 'b', 'r'}) <class 'frozenset'>

面試題:

  有li = [1, 21, 22, 22, 1, 8, 21],請將li內重復的元素保留一個並輸出新li1
li = [1, 21, 22, 22, 1, 8, 21]
li1 = list(set(li))
print(li1)
View Code

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM