簡介
set:set對象是由hashable 對象所組成的無序集合,set對象的每一個(gè)元素要求可進(jìn)行哈希運(yùn)算,set 會(huì)對內(nèi)部元素進(jìn)行去重,每個(gè)元素在同一個(gè)set 中只會(huì)出現(xiàn)一次,由于set對象可變性,所以set 對象自身不可哈希。
frozenset: frozenset 對象可以看成一個(gè)不可變set對象,是一個(gè)可哈希對象,可以最為frozenset、set 的元素或 dict 的 key 。
創(chuàng)建set對象
可哈希對象:在python常見的數(shù)據(jù)類型中,數(shù)值類型,字符串,元組,frozenset,bytes等屬于可哈希對象。
創(chuàng)新互聯(lián)建站-專業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性價(jià)比祁門網(wǎng)站開發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫,直接使用。一站式祁門網(wǎng)站制作公司更省心,省錢,快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋祁門地區(qū)。費(fèi)用合理售后完善,十載實(shí)體公司更值得信賴。
# 直接創(chuàng)建
s1 = {1, 2, (1, 4), 'b', 0x23, "\x61"} # 內(nèi)部元素為可哈希對象
s2 = set() # 空set,不可使用s = { }
# set( iter ) # 可迭代對象
s3 = set(range(5))
集合常用方法
frozenset的創(chuàng)建方法和set相同, 其他 共同的方法如下
# 向集合增加一個(gè)元素
s1 = set(range(5))
s1.add(6)
s1.add(4) # 當(dāng)元素在set中已經(jīng)存在,添加后set會(huì)自動(dòng)對其去重
# 集合中刪除元素
s1.remove(6) # 從集合中移除元素 6。如果 6 不存在于集合中則會(huì)引發(fā)KeyError。
s1.discard(4) # 如果元素 4 存在于集合中則將其移除,無返回值
s1.pop() # 從集合中移除并返回任意一個(gè)元素。如果集合為空則會(huì)引發(fā)KeyError。
s1.clear() # 從集合中移除所有元素
集合運(yùn)算
- isdisjoint(other)
如果集合中沒有與 other 共有的元素則返回 True。當(dāng)且僅當(dāng)兩個(gè)集合的交集為空集合時(shí),兩者為不相交集合。- issubset(other)
set <= other
檢測是否集合中的每個(gè)元素都在 other 之中。
set < other
檢測集合是否為 other 的真子集,即 set <= other and set != other。- issuperset(other)
set >= other
檢測是否 other 中的每個(gè)元素都在集合之中。
set > other
檢測集合是否為 other 的真超集,即 set >= other and set != other。- union(*others)
set | other | ...
返回一個(gè)新集合,其中包含來自原集合以及 others 指定的所有集合中的元素。- intersection(*others)
set & other & ...
返回一個(gè)新集合,其中包含原集合以及 others 指定的所有集合中共有的元素。- difference(*others)
set - other - ...
返回一個(gè)新集合,其中包含原集合中在 others 指定的其他集合中不存在的元素。- symmetric_difference(other)
set ^ other
返回一個(gè)新集合,其中的元素或?qū)儆谠匣驅(qū)儆?other 指定的其他集合,但不能同時(shí)屬于兩者。- copy()
返回原集合的淺拷貝。
可以使用set運(yùn)算直接進(jìn)行運(yùn)算,運(yùn)算方式和數(shù)學(xué)中集合運(yùn)算方式相同,例如:
s1 = set(range(10))
s2 = set(range(5,15))
# s1 ==> {0, 1, 2, 3, 4, 5, 6, 7, 8, 9}
# s2 ==> {5, 6, 7, 8, 9, 10, 11, 12, 13, 14}
# 交集
s3 = s1 & s2 # {5, 6, 7, 8, 9}
# 并集
s3 = s1 | s2 # {0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14}
# 差集:從s1 中減去s2 中存在的元素
s5 = s1 - s2 # {10, 11, 12, 13, 14}
# 子集:
{1,2,4} <= {1,2,3,4} # True
# 對稱差集: 返回兩個(gè)集合中不同的元素
s6 = s1 ^ s2 # {0, 1, 2, 3, 4, 10, 11, 12, 13, 14}
frozenset 和 set 對象的比較是基于內(nèi)部元素的比較,兩個(gè)對象之間仍可以進(jìn)行以上運(yùn)算,但是運(yùn)算結(jié)果是一個(gè)frozenset 對象,而不是set對象;
字典可以將一個(gè)可哈希值映射到一個(gè)任意對象,可以通過映射關(guān)系快速查找對應(yīng)數(shù)據(jù);所以在dict中的每一項(xiàng)由一個(gè)key-value對組成(也稱pairs) ,其中key 會(huì)作為字典快速查找的的一個(gè)關(guān)鍵數(shù)據(jù),所以要求一個(gè)字典中鍵必須是唯一,并可哈希,若在賦值過程中出現(xiàn)相同的key值,后者將會(huì)覆蓋之前的內(nèi)容。
創(chuàng)建dict對象
# key = value 鍵值對方式
d1 = dict( a=1,b=2,c=3 ) # {'a':1, 'b':2, 'c':3}
# mapping 對象創(chuàng)建
d2 = dict(d1, d =4 ) # {'a':1, 'b':2, 'c':3, 'd':4}
# iterable對象,對象中每一個(gè)元素必須有兩個(gè)值分別作為key 和 value
d3 = dicrt([(1,2),(3,4),(5,6)]) # {1:2, 3:4, 5:6}
字典中方法
__massing__()
方法,d[key]將會(huì)以__missing__()
的return值作為d[key] 的內(nèi)容# 該類實(shí)現(xiàn)了collections.defaultdict() 類相同的方法
class MyDict(dict):
def __init__(self, seq=list):
super().__init__
self.seq = seq
def __missing__(self, key):
return self.setdefault(key,self.seq())
mydic = MyDict(set)
for i in "abc":
mydic[i].add(1)
mydic["c"] # {1}
mydic # {'a': {1}, 'b': {1}, 'c': {1}}
# 批量造 key, 用列表,字符串,
# .fromkeys(iter, value)
d8 = dict.fromkeys(range(4), 100)
d8 # {0: 100, 1: 100, 2: 100, 3: 100}
d = {'a':1, 'b':2, 'c':3, 'd':4}
d["k"] # 找不到"k",將會(huì)報(bào)錯(cuò)
d.get("k", -1) # .get(key, default) # 找不到會(huì)返回設(shè)定的默認(rèn)值-1
d.setdefault("k", 10) # 若"k" 存在,返回k的值,若不存在"k"不存在將會(huì)執(zhí)行賦值操作d["k"] = 10,并返回 10
d = {'a':1, 'b':2, 'c':3, 'd':4}
d.setdefault("k",100) # setdefault(k, default=None)
d # {'a':1, 'b':2, 'c':3, 'd':4,'k':100}
update([other]):使用來自 other 的鍵/值對更新字典,覆蓋原有的鍵。返回 None。
d = {'a':1, 'b':2, 'c':3, 'd':4}
for key in d.keys():
d.pop(key) # 改變字典長度,將會(huì)報(bào)錯(cuò)
# 解決方案
d = {'a':1, 'b':2, 'c':3, 'd':4}
for key in list(d.keys()): # 此時(shí)將dict視圖對象提前遍歷生成列表,再對列表進(jìn)行遍歷,不是對視圖對象的遍歷,將不會(huì)報(bào)錯(cuò)
d.pop(key)