Python數(shù)據(jù)結(jié)構(gòu)集合的相關(guān)詳解
Python數(shù)據(jù)結(jié)構(gòu)集合
集合是一種無序、可變的數(shù)據(jù)結(jié)構(gòu),它也是一種變量類型,集合用于存儲(chǔ)唯一的元素。集合中的元素不能重復(fù),并且沒有固定的順序。
在Python 提供了內(nèi)置的 set
類型來表示集合,所以關(guān)鍵字set
就是集合的意思。
你可以使用大括號(hào) {}
或者 set()
函數(shù)來創(chuàng)建一個(gè)集合。
my_set = {1, 2, 3} # 使用大括號(hào)創(chuàng)建集合 print(my_set) # 輸出: {1, 2, 3} my_set = set([1, 2, 3]) # 使用 set() 函數(shù)創(chuàng)建集合 print(my_set) # 輸出: {1,2, 3}
需要注意的是,集合是無序的,沒有固定的順序。因此,集合元素的順序可能與你創(chuàng)建或添加的順序不同。
集合具有以下特點(diǎn):
- 集合中的元素是唯一的,不重復(fù)。如果重復(fù)相同的元素,集合將自動(dòng)去重。
- 集合是無序的,沒有固定的順序。因此,你無法像列表或元組那樣索引來訪問集合中的元素。
- 集合是可迭代的,你可以使用
for
循環(huán)遍歷集合中的元素。 - 集合是可變的,你可以添加、刪除和修改集合中的元素
創(chuàng)建集合
要使用集合,首先就必須要?jiǎng)?chuàng)建,那么在 Python 中,有哪些創(chuàng)建集合的方式呢?你可以使用以下幾種方式創(chuàng)建集合。
1、 使用大括號(hào) {}
或者 set()
函數(shù)創(chuàng)建一個(gè)集合,將元素用逗號(hào)隔開:
my_set = {1, 2, 3} # 使用大括號(hào)創(chuàng)建集合 print(my_set) # 輸出: {1, 2, 3} my_set = set([1, 2, 3]) # 使用 set() 函數(shù)創(chuàng)建集合 print(my_set) # 輸出: {1, 2, 3}
注意,如果你使用空的大括號(hào) {}
來創(chuàng)建一個(gè)對象,那么創(chuàng)建的將是一個(gè)空字典,而非空集合。因此,你必須使用 set()
函數(shù)來創(chuàng)建一個(gè)空集合:
empty_set = set() print(empty_set) # 輸出: set()
2、 使用集合推導(dǎo)式來創(chuàng)建集合。集合推導(dǎo)式的語法類似于列表推導(dǎo)式,只需將中括號(hào) [ ]
替換為大括號(hào) { }
:
my_set = {i for i in range(1, 5)} print(my_set) # 輸出: {1, 2, 3, 4}
3、 將其他可迭代的對象(列表、字符串、元組等)轉(zhuǎn)換為集合,可以使用 set()
函數(shù)來實(shí)現(xiàn):
my_list = [1, 2, 3, 2] my_set = set(my_list) print(my_set) # 輸出: {1, 2, 3} my_string = 'hello' my_set ={my_string} print(my_set) # 輸出: {'h', 'e', 'l', 'o'}
訪問集合
由于集合是無序的,沒有固定的索引,使用索引訪問集合中的元素是不可行的,要訪問集合中的元素,你可以使用迭代器或者通過成員運(yùn)算符來實(shí)現(xiàn)。
1、 使用迭代器:通過使用 for 循環(huán)遍歷集合中的每個(gè)元素。
my_set = {1, 2, 3} for item in my_set: print(item)
2、 使用成員運(yùn)算:使用 in
或者 not in
運(yùn)算符來檢查元素是否存在于集合中。
my_set = {1, 2, 3} print(2 in my_set) # 輸出: True print(4 not in my_set) # 輸出: True
刪除集合
在 Python 中,可以使用 del
關(guān)鍵字來刪除集合:
1、 使用 del
關(guān)鍵字刪除集合變量,刪除之后如果再次訪問,就會(huì)發(fā)生錯(cuò)誤。
my_set = {1, 2, 3} del my_set
修改集合元素
創(chuàng)建的集合,我們可以對其中的集合元素進(jìn)行操作,不僅可以添加元素,還是可以刪除其中的元素。
添加集合元素
1、使用 add()
方法向集合中添加元素。
my_set = {1, 2, 3} my_set.add(4) print(my_set) # 輸出: {1, 2, 3, 4}
2、使用列表的解包操作添加多個(gè)元素。
my_set = {1, 2, 3} new_elements = [4, 5] my_set.update(new_elements) print(my_set) # 輸出: {1, 2, 3, 4, 5}
因?yàn)榧系脑厥俏ㄒ坏?,所以如果添加了重?fù)的元素,那么重復(fù)的元素不會(huì)被添加到集合中,當(dāng)然執(zhí)行的過程并不會(huì)發(fā)生報(bào)錯(cuò),只是不會(huì)被添加進(jìn)去而已。在使用update()
方法時(shí),傳入的參數(shù)可以是一個(gè)集合、列表或者其他可迭代對象。
刪除集合元素
1、 使用 remove()
方法刪除指定元素:remove()
方法會(huì)從集合中刪除指定的元素。如果集合中不存在該元素,會(huì)引發(fā) KeyError
異常。
my_set = {1, 2, 3, 4} my_set.remove(3) print(my_set) # 輸出: {1, 2,4} my_set.remove(5) # 刪除不存在的元素,引發(fā) KeyError 異常
2、 使用 discard()
方法刪除指定元素:discard()
方法會(huì)從集合中刪除指定的元素。如果集合不存在該元素,該不會(huì)引發(fā)異常而是不進(jìn)行任何操作。
my_set = {1, 2, 3 4} my_set.discard(3) (my_set) # 輸出: {1, 2, 4} my_set.discard(5) # 刪除不存在的元素,不會(huì)引發(fā)異常
3、 clear()
方法清空集合:clear()
方法會(huì)清空集合元素。
my_set = {1, 2, 3, 4} my_set.clear() print(my_set) # 輸出: set()
集合運(yùn)算:
集合的運(yùn)算指的是對集合進(jìn)行一系列操作,包括求并集、交集、差集和對稱差集等。這些運(yùn)算可通過運(yùn)算符或方法來進(jìn)行。
并集(Union)
可以使用 |
運(yùn)算符或者 union()
方法來獲取兩個(gè)集合的并集。所謂的并集就是包含set1和set2集合的所有元素。
set1 = {1, 2, 3} set2 = {3, 4, 5} set3 = set1 | set2 # 使用 | 運(yùn)算符 # 或者使用 union() 方法 # set3 = set1.union(set2) print(set3) # 輸出: {1, 2, 3, 4, 5}
交集(Intersection)
可以使用 &
運(yùn)算符或者 intersection()
方法來獲取兩個(gè)集合的交集。所謂的交集就是取set1和set2集合的相同元素,沒有相同元素的話返回的就是set()
。
set1 = {1, 2, 3} set2 = {3, 4, 5} set3 = set1 & set2 # 使用 & 運(yùn)算符 # 或者使用 intersection() 方法 # set3 = set1.intersection(set2) print(set3) # 輸出: {3}
差集(Difference)
可以使用 -
運(yùn)算符或者 difference()
方法來獲取兩個(gè)集合的差集。所謂的差集就是set1中獨(dú)有
的元素,如果set1中的元素,在set2中也有,那么就該元素就不能在差集中。如果是set2 - set1
,那就是set2中獨(dú)有的元素。結(jié)果為空的返回就是set()
。
set1 = {1, 2, 3} set2 = {3, 4, 5} set3 = set1 - set2 # 使用 - 運(yùn)算符 # 或者使用 difference() 方法 # set3 = set1.difference(set2) print(set3) # 輸出: {1, 2}
對稱差集(Symmetric Difference)
可以使用 ^
運(yùn)算符或者 symmetric_difference()
方法來獲取兩個(gè)集合的對稱差集。所謂的對稱差集就是set1和set2中相同的元素剔除,剩下的元素就是對稱差集。
set1 = {1, 2, 3} set2 = {3, 4, 5} set3 = set1 ^ set2 #使用 ^ 運(yùn)算符 # 或者使用 symmetric_difference() 方法 # set3 = set1.symmetric_difference(set2) print(set3) # 輸出: {1, 2, 4, 5}
需要注意的是,在使用集合運(yùn)算符時(shí),兩個(gè)集合的元素類型必須一致。另外,集合的元素是唯一的,不會(huì)出現(xiàn)重復(fù)。
除了運(yùn)算符外,還有其他一些常用的集合方法,比如 intersection_update()
方法用于在原集合上更新為兩個(gè)集合的交集,difference_update()
方法用于在原集合上更新為兩個(gè)集合的差集,symmetric_difference_update()
方法用于在原集合上更新為兩個(gè)集合的對稱差集。
集合的相關(guān)函數(shù)
Python中的集合也有不少相關(guān)的方法,以下就是列舉了集合中常用的方法,如有錯(cuò)誤的地方歡迎指出。
函數(shù)名 | 解釋 |
---|---|
add(element) | 向集合中添加一個(gè)元素。 |
clear() | 移除集合中的所有元素。 |
copy() | 返回集合的副本。 |
difference(other_set[, ...]) | 返回該集合與其他集合的差集。 |
difference_update(other_set[, ...]) | 移除該集合中與其他集合相同的元素,并更新原集合。 |
discard(element) | 移除集合中指定的元素。 |
intersection(other_set[, ...]) | 返回該集合與其他集合的交集。 |
intersection_update(other_set[, ...]) | 移除該集合中與其他集合不同的元素,并更新原集合。 |
isdisjoint(other_set) | 如果兩個(gè)集合沒有共同的元素,則返回 True;否則返回 False。 |
issubset(other_set) | 如果該集合是另一個(gè)集合的子集,則返回 True;否則返回 False。 |
issuperset(other_set) | 如果該集合是另一個(gè)集合的超集,則返回 True;否則返回 False。 |
pop() | 隨機(jī)移除并返回集合中的一個(gè)元素。 |
remove(element) | 移除集合中指定的元素。若元素不存在,將引發(fā) KeyError 錯(cuò)誤。 |
symmetric_difference(other_set) | 返回該集合與其他集合的對稱差集。 |
symmetric_difference_update(other_set) | 移除該集合中與其他集合相同的元素,并更新原集合。 |
union(other_set[, ...]) | 返回該集合與其他集合的并集。 |
update(other_set[, ...]) | 向集合中添加其他集合的元素,并更新原集合。 |
總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Python邊緣檢測之prewitt,sobel和laplace算子詳解
這篇文章主要為大家詳細(xì)介紹了Python邊緣檢測中prewitt、sobel和laplace算子的使用方法,文中的示例代碼講解詳細(xì),感興趣的小伙伴可以了解一下2023-04-04Python 反轉(zhuǎn)字符串(reverse)的方法小結(jié)
這篇文章主要介紹了Python 反轉(zhuǎn)字符串(reverse)的方法小結(jié),需要的朋友可以參考下2018-02-02詳談Python基礎(chǔ)之內(nèi)置函數(shù)和遞歸
下面小編就為大家?guī)硪黄狿ython基礎(chǔ)之內(nèi)置函數(shù)和遞歸。小編覺得挺不錯(cuò)的?,F(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-06-06Python3 無重復(fù)字符的最長子串的實(shí)現(xiàn)
這篇文章主要介紹了Python3 無重復(fù)字符的最長子串的實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10Django中在xadmin中集成DjangoUeditor過程詳解
這篇文章主要介紹了Django中在xadmin中集成DjangoUeditor過程詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07Python?遞歸式實(shí)現(xiàn)二叉樹前序,中序,后序遍歷
這篇文章主要介紹了Python?遞歸式實(shí)現(xiàn)二叉樹前序,中序,后序遍歷,更多相關(guān)資料,需要的小伙伴可以參考下面具體的文章內(nèi)容2022-03-03python統(tǒng)計(jì)指定目錄內(nèi)文件的代碼行數(shù)
這篇文章主要介紹了python統(tǒng)計(jì)指定目錄內(nèi)文件的代碼行數(shù)2019-09-09