成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Python集合是什么,為什么應(yīng)該使用以及如何使用?

開(kāi)發(fā) 后端
Python 配備了幾種內(nèi)置數(shù)據(jù)類型來(lái)幫我們組織數(shù)據(jù)。這些結(jié)構(gòu)包括列表、字典、元組和集合。在本文中,我們將回顧并查看上述定義中列出的每個(gè)要素的示例。讓我們馬上開(kāi)始,看看如何創(chuàng)建它。

[[238266]]

Python Sets: What, Why and How

Python Sets: What, Why and How

Python 配備了幾種內(nèi)置數(shù)據(jù)類型來(lái)幫我們組織數(shù)據(jù)。這些結(jié)構(gòu)包括列表、字典、元組和集合。

根據(jù) Python 3 文檔:

集合是一個(gè)無(wú)序集合,沒(méi)有重復(fù)元素。基本用途包括成員測(cè)試消除重復(fù)的條目。集合對(duì)象還支持?jǐn)?shù)學(xué)運(yùn)算,如并集交集差集對(duì)等差分

在本文中,我們將回顧并查看上述定義中列出的每個(gè)要素的示例。讓我們馬上開(kāi)始,看看如何創(chuàng)建它。

 

初始化一個(gè)集合

有兩種方法可以創(chuàng)建一個(gè)集合:一個(gè)是給內(nèi)置函數(shù) set() 提供一個(gè)元素列表,另一個(gè)是使用花括號(hào) {}

使用內(nèi)置函數(shù) set() 來(lái)初始化一個(gè)集合:

  1. >>> s1 = set([1, 2, 3])
  2. >>> s1
  3. {1, 2, 3}
  4. >>> type(s1)
  5. <class 'set'>

使用 {}

  1. >>> s2 = {3, 4, 5}
  2. >>> s2
  3. {3, 4, 5}
  4. >>> type(s2)
  5. <class 'set'>
  6. >>>

如你所見(jiàn),這兩種方法都是有效的。但問(wèn)題是,如果我們想要一個(gè)空的集合呢?

  1. >>> s = {}
  2. >>> type(s)
  3. <class 'dict'>

沒(méi)錯(cuò),如果我們使用空花括號(hào),我們將得到一個(gè)字典而不是一個(gè)集合。=)

值得一提的是,為了簡(jiǎn)單起見(jiàn),本文中提供的所有示例都將使用整數(shù)集合,但集合可以包含 Python 支持的所有 可哈希的hashable 數(shù)據(jù)類型。換句話說(shuō),即整數(shù)、字符串和元組,而不是列表字典這樣的可變類型。

  1. >>> s = {1, 'coffee', [4, 'python']}
  2. Traceback (most recent call last):
  3. File "<stdin>", line 1, in <module>
  4. TypeError: unhashable type: 'list'

既然你知道了如何創(chuàng)建一個(gè)集合以及它可以包含哪些類型的元素,那么讓我們繼續(xù)看看為什么我們總是應(yīng)該把它放在我們的工具箱中。

 

為什么你需要使用它

寫(xiě)代碼時(shí),你可以用不止一種方法來(lái)完成它。有些被認(rèn)為是相當(dāng)糟糕的,另一些則是清晰的、簡(jiǎn)潔的和可維護(hù)的,或者是 “Python 式的pythonic”。

根據(jù) Hitchhiker 對(duì) Python 的建議:

當(dāng)一個(gè)經(jīng)驗(yàn)豐富的 Python 開(kāi)發(fā)人員(Python 人Pythonista)調(diào)用一些不夠 “Python 式的pythonic” 的代碼時(shí),他們通常認(rèn)為著這些代碼不遵循通用指南,并且無(wú)法被認(rèn)為是以一種好的方式(可讀性)來(lái)表達(dá)意圖。

讓我們開(kāi)始探索 Python 集合那些不僅可以幫助我們提高可讀性,還可以加快程序執(zhí)行時(shí)間的方式。

 

無(wú)序的集合元素

首先你需要明白的是:你無(wú)法使用索引訪問(wèn)集合中的元素。

  1. >>> s = {1, 2, 3}
  2. >>> s[0]
  3. Traceback (most recent call last):
  4. File "<stdin>", line 1, in <module>
  5. TypeError: 'set' object does not support indexing

或者使用切片修改它們:

  1. >>> s[0:2]
  2. Traceback (most recent call last):
  3. File "<stdin>", line 1, in <module>
  4. TypeError: 'set' object is not subscriptable

但是,如果我們需要?jiǎng)h除重復(fù)項(xiàng),或者進(jìn)行組合列表(與)之類的數(shù)學(xué)運(yùn)算,那么我們可以,并且應(yīng)該始終使用集合。

我不得不提一下,在迭代時(shí),集合的表現(xiàn)優(yōu)于列表。所以,如果你需要它,那就加深對(duì)它的喜愛(ài)吧。為什么?好吧,這篇文章并不打算解釋集合的內(nèi)部工作原理,但是如果你感興趣的話,這里有幾個(gè)鏈接,你可以閱讀它:

 

沒(méi)有重復(fù)項(xiàng)

寫(xiě)這篇文章的時(shí)候,我總是不停地思考,我經(jīng)常使用 for 循環(huán)和 if 語(yǔ)句檢查并刪除列表中的重復(fù)元素。記得那時(shí)我的臉紅了,而且不止一次,我寫(xiě)了類似這樣的代碼:

  1. >>> my_list = [1, 2, 3, 2, 3, 4]
  2. >>> no_duplicate_list = []
  3. >>> for item in my_list:
  4. ... if item not in no_duplicate_list:
  5. ... no_duplicate_list.append(item)
  6. ...
  7. >>> no_duplicate_list
  8. [1, 2, 3, 4]

或者使用列表解析:

  1. >>> my_list = [1, 2, 3, 2, 3, 4]
  2. >>> no_duplicate_list = []
  3. >>> [no_duplicate_list.append(item) for item in my_list if item not in no_duplicate_list]
  4. [None, None, None, None]
  5. >>> no_duplicate_list
  6. [1, 2, 3, 4]

但沒(méi)關(guān)系,因?yàn)槲覀儸F(xiàn)在有了武器裝備,沒(méi)有什么比這更重要的了:

  1. >>> my_list = [1, 2, 3, 2, 3, 4]
  2. >>> no_duplicate_list = list(set(my_list))
  3. >>> no_duplicate_list
  4. [1, 2, 3, 4]
  5. >>>

現(xiàn)在讓我們使用 timeit 模塊,查看列表和集合在刪除重復(fù)項(xiàng)時(shí)的執(zhí)行時(shí)間:

  1. >>> from timeit import timeit
  2. >>> def no_duplicates(list):
  3. ... no_duplicate_list = []
  4. ... [no_duplicate_list.append(item) for item in list if item not in no_duplicate_list]
  5. ... return no_duplicate_list
  6. ...
  7. >>> # 首先,讓我們看看列表的執(zhí)行情況:
  8. >>> print(timeit('no_duplicates([1, 2, 3, 1, 7])', globals=globals(), number=1000))
  9. 0.0018683355819786227
  1. >>> from timeit import timeit
  2. >>> # 使用集合:
  3. >>> print(timeit('list(set([1, 2, 3, 1, 2, 3, 4]))', number=1000))
  4. 0.0010220493243764395
  5. >>> # 快速而且干凈 =)

使用集合而不是列表推導(dǎo)不僅讓我們編寫(xiě)更少的代碼,而且還能讓我們獲得更具可讀性高性能的代碼。

注意:請(qǐng)記住集合是無(wú)序的,因此無(wú)法保證在將它們轉(zhuǎn)換回列表時(shí),元素的順序不變。

Python 之禪

優(yōu)美勝于丑陋Beautiful is better than ugly.

明了勝于晦澀Explicit is better than implicit.

簡(jiǎn)潔勝于復(fù)雜Simple is better than complex.

扁平勝于嵌套Flat is better than nested.

集合不正是這樣美麗、明了、簡(jiǎn)單且扁平嗎?

 

成員測(cè)試

每次我們使用 if 語(yǔ)句來(lái)檢查一個(gè)元素,例如,它是否在列表中時(shí),意味著你正在進(jìn)行成員測(cè)試:

  1. my_list = [1, 2, 3]
  2. >>> if 2 in my_list:
  3. ... print('Yes, this is a membership test!')
  4. ...
  5. Yes, this is a membership test!

在執(zhí)行這些操作時(shí),集合比列表更高效:

  1. >>> from timeit import timeit
  2. >>> def in_test(iterable):
  3. ... for i in range(1000):
  4. ... if i in iterable:
  5. ... pass
  6. ...
  7. >>> timeit('in_test(iterable)',
  8. ... setup="from __main__ import in_test; iterable = list(range(1000))",
  9. ... number=1000)
  10. 12.459663048726043
  1. >>> from timeit import timeit
  2. >>> def in_test(iterable):
  3. ... for i in range(1000):
  4. ... if i in iterable:
  5. ... pass
  6. ...
  7. >>> timeit('in_test(iterable)',
  8. ... setup="from __main__ import in_test; iterable = set(range(1000))",
  9. ... number=1000)
  10. .12354438152988223

注意:上面的測(cè)試來(lái)自于這個(gè) StackOverflow 話題。

因此,如果你在巨大的列表中進(jìn)行這樣的比較,嘗試將該列表轉(zhuǎn)換為集合,它應(yīng)該可以加快你的速度。

 

如何使用

現(xiàn)在你已經(jīng)了解了集合是什么以及為什么你應(yīng)該使用它,現(xiàn)在讓我們快速瀏覽一下,看看我們?nèi)绾涡薷暮筒僮魉?/p>

 

添加元素

根據(jù)要添加的元素?cái)?shù)量,我們要在 add()update() 方法之間進(jìn)行選擇。

add() 適用于添加單個(gè)元素:

  1. >>> s = {1, 2, 3}
  2. >>> s.add(4)
  3. >>> s
  4. {1, 2, 3, 4}

update() 適用于添加多個(gè)元素:

  1. >>> s = {1, 2, 3}
  2. >>> s.update([2, 3, 4, 5, 6])
  3. >>> s
  4. {1, 2, 3, 4, 5, 6}

請(qǐng)記住,集合會(huì)移除重復(fù)項(xiàng)。

 

移除元素

如果你希望在代碼中嘗試刪除不在集合中的元素時(shí)收到警報(bào),請(qǐng)使用 remove()。否則,discard() 提供了一個(gè)很好的選擇:

  1. >>> s = {1, 2, 3}
  2. >>> s.remove(3)
  3. >>> s
  4. {1, 2}
  5. >>> s.remove(3)
  6. Traceback (most recent call last):
  7. File "<stdin>", line 1, in <module>
  8. KeyError: 3

discard() 不會(huì)引起任何錯(cuò)誤:

  1. >>> s = {1, 2, 3}
  2. >>> s.discard(3)
  3. >>> s
  4. {1, 2}
  5. >>> s.discard(3)
  6. >>> # 什么都不會(huì)發(fā)生

我們也可以使用 pop() 來(lái)隨機(jī)丟棄一個(gè)元素:

  1. >>> s = {1, 2, 3, 4, 5}
  2. >>> s.pop() # 刪除一個(gè)任意的元素
  3. 1
  4. >>> s
  5. {2, 3, 4, 5}

或者 clear() 方法來(lái)清空一個(gè)集合:

  1. >>> s = {1, 2, 3, 4, 5}
  2. >>> s.clear() # 清空集合
  3. >>> s
  4. set()

 

union()

union() 或者 | 將創(chuàng)建一個(gè)新集合,其中包含我們提供集合中的所有元素:

  1. >>> s1 = {1, 2, 3}
  2. >>> s2 = {3, 4, 5}
  3. >>> s1.union(s2) # 或者 's1 | s2'
  4. {1, 2, 3, 4, 5}

 

intersection()

intersection& 將返回一個(gè)由集合共同元素組成的集合:

  1. >>> s1 = {1, 2, 3}
  2. >>> s2 = {2, 3, 4}
  3. >>> s3 = {3, 4, 5}
  4. >>> s1.intersection(s2, s3) # 或者 's1 & s2 & s3'
  5. {3}

 

difference()

使用 diference()- 創(chuàng)建一個(gè)新集合,其值在 “s1” 中但不在 “s2” 中:

  1. >>> s1 = {1, 2, 3}
  2. >>> s2 = {2, 3, 4}
  3. >>> s1.difference(s2) # 或者 's1 - s2'
  4. {1}

 

symmetric_diference()

symetric_difference^ 將返回集合之間的不同元素。

  1. >>> s1 = {1, 2, 3}
  2. >>> s2 = {2, 3, 4}
  3. >>> s1.symmetric_difference(s2) # 或者 's1 ^ s2'
  4. {1, 4}

 

結(jié)論

我希望在閱讀本文之后,你會(huì)知道集合是什么,如何操縱它的元素以及它可以執(zhí)行的操作。知道何時(shí)使用集合無(wú)疑會(huì)幫助你編寫(xiě)更清晰的代碼并加速你的程序。

如果你有任何疑問(wèn),請(qǐng)發(fā)表評(píng)論,我很樂(lè)意嘗試回答。另外,不要忘記,如果你已經(jīng)理解了集合,它們?cè)?Python Cheatsheet 中有自己的一席之地,在那里你可以快速參考并重新認(rèn)知你已經(jīng)知道的內(nèi)容。 

責(zé)任編輯:龐桂玉 來(lái)源: Linux中國(guó)
相關(guān)推薦

2011-04-14 09:30:15

集合框架

2018-06-08 15:27:59

云計(jì)算企業(yè)存儲(chǔ)

2022-05-16 09:27:37

UbuntuUbuntu LTS

2024-06-28 07:59:34

C#編程字段

2012-08-13 09:15:54

Go開(kāi)發(fā)語(yǔ)言編程語(yǔ)言

2020-06-05 14:09:42

Kubernetes容器應(yīng)用程序

2018-07-09 14:05:16

編程語(yǔ)言PythonPipenv

2022-01-23 13:51:30

Arch LinuxLinux

2023-01-24 17:08:08

深度學(xué)習(xí)高斯噪聲數(shù)據(jù)生成器

2021-04-25 15:06:16

微軟虛擬桌面IT

2024-01-09 13:43:05

CMSCRM

2023-04-04 07:15:01

2016-03-24 09:53:24

swiftguardios

2019-01-10 13:17:15

微服務(wù)容器微服務(wù)架構(gòu)

2021-03-14 15:17:13

前端開(kāi)發(fā)架構(gòu)

2021-05-08 14:00:58

FedoraLinux

2020-06-21 21:25:14

物聯(lián)網(wǎng)WiFiIOT

2021-08-30 10:27:49

SaaS公有云云計(jì)算

2012-09-26 10:02:44

框架開(kāi)發(fā)項(xiàng)目

2020-04-07 13:40:13

GraphQLAPI編程語(yǔ)言
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 午夜视频网站 | 激情六月丁香 | 久久久久久成人 | 一级毛片网 | 色视频免费| 亚洲精品一二三区 | 九九综合 | 亚洲午夜精品 | 国内精品久久久久久 | 亚洲欧美一区二区三区1000 | 亚洲国产精品视频一区 | 免费精品久久久久久中文字幕 | 欧美日韩看片 | 亚洲欧美一区二区三区在线 | 久久综合成人精品亚洲另类欧美 | 日韩欧美天堂 | 特级做a爰片毛片免费看108 | 日韩欧美高清dvd碟片 | 日韩中文字幕高清 | 91精品国产91久久久久久 | 中文字字幕一区二区三区四区五区 | 亚洲国产免费 | 日韩精品亚洲专区在线观看 | 亚洲午夜精品一区二区三区他趣 | 一区二区在线免费播放 | 欧美成人激情 | 亚洲午夜精品在线观看 | 激情视频中文字幕 | 国产日本精品视频 | 最新国产精品 | 视频二区国产 | 国产精品毛片在线 | 蜜桃毛片| 日本在线播放一区二区 | 久久se精品一区精品二区 | 欧美午夜精品 | 9久9久9久女女女九九九一九 | 国产免费视频 | 国产一区2区| 日韩高清在线观看 | 亚洲精品乱码久久久久久按摩观 |