Python高級數據類型之字典、集合

上一篇我們簡單對Python的基礎數據類型做了說明和講【Python高級數據類型之列表,元組】,本篇我們繼續針對Python的數據類型進行高級數據類型的介紹。

我們來先看一張圖表:

列表 元組 集合 字典
英文 list tuple set dict
可否重複
可否讀寫 讀寫 只讀 讀寫 讀寫
存儲方式 鍵(不能複復) 鍵值對(鍵不能重複)
是否有序 有序 有序 無序 無序(自動正序)
初始化 [1,‘b’] (1,‘b’) set([1,2])或者{1,2} {‘a’:1,‘b’:2}
添加 append 只讀 add d[‘key’]=‘value’
讀元素 l[0:2] t[0] d[‘a’]

字典(dict)

字典(dictionary)是Python中另一個非常有用的內置數據類型。字典類似於你通過聯繫人名稱查找地址和聯繫人詳細情況的地址簿,即,我們把鍵(名字)和值(詳細情況)聯繫在一起。注意,鍵必須是唯一的,就像如果有兩個人恰巧同名的話,你無法找到正確的信息。也由於這種(key - value)模式,所以對於索引查找的速度極快。

字典在其它語言裏就是數組。

還是使用代碼來進行演示。

dict = {'Name': '明哥', 'Age': 35, 'Work': '架構師'}
print("#顯示初始化!")
for k in dict.keys():
   print("%s : %s " % (k,dict[k]))
dict['Age'] = 36 #更新Age
dict['Work'] = "數據分析師"
print("#顯示更新後的值")
for k in dict.keys():
   print("%s : %s " % (k,dict[k]))
# 添加信息
del dict['Name'] # 刪除鍵 'Name'
print("#刪除Name後的值")
for k in dict.keys():
   print("%s : %s " % (k,dict[k]))
dict.clear()     # 清空字典
print("#顯示clear後的值")
print(dict)

我們首先定義了一個字典,包含明哥的年齡,職業。到了2020年,修改了年齡,和工作。因爲保密,所以刪除名字,最後完成任務,我們清除了這個字典值

#顯示初始化!
Name : 明哥 
Age : 35 
Work : 架構師 
#顯示更新後的值
Name : 明哥 
Age : 36 
Work : 數據分析師 
#刪除Name後的值
Age : 36 
Work : 數據分析師 
#顯示clear後的值
{}

如果用字典裏沒有的鍵訪問數據,會輸出錯誤如下:KeyError: ‘xxx’

序號 函數及描述 說明
1 radiansdict.clear() 刪除字典內所有元素
2 radiansdict.copy() 返回一個字典的淺複製
3 radiansdict.fromkeys() 創建一個新字典,以序列seq中元素做字典的鍵,val爲字典所有鍵對應的初始值
4 radiansdict.get(key, default=None) 返回指定鍵的值,如果值不在字典中返回default值
5 key in dict 如果鍵在字典dict裏返回true,否則返回false
6 radiansdict.items() 以列表返回可遍歷的(鍵, 值) 元組數組
7 radiansdict.keys() 返回一個迭代器,可以使用 list() 來轉換爲列表
8 radiansdict.setdefault(key, default=None) 和get()類似, 但如果鍵不存在於字典中,將會添加鍵並將值設爲default
9 radiansdict.update(dict2) 把字典dict2的鍵/值對更新到dict裏

集合(set)

集合(set)是一個無序不重複元素的序列。特性:與字典類似,但只包含鍵,而沒有對應的值,包含的數據不重複。

set可以看成數學意義上的無序和無重複元素的集合,因此,兩個set可以做數學意義上的交集、並集等操作。set和dict的唯一區別僅在於沒有存儲對應的value,但是,set的原理和dict一樣,所以,同樣不可以放入可變對象,因爲無法判斷兩個可變對象是否相等,也就無法保證set內部“不會有重複元素”。試試把list放入set,看看是否會報錯。

還是代碼演示:

print("初始化一個重複集合")
s = set([2,3,1, 1, 2, 2, 3, 3])
print(s)
print("添加11,和1 ,打印看結果")
s.add(4)
s.add(1)
print(s)
s.remove(1)
print("移除1")
print(s)

#新建一個集合
s1 = set([1,3,4,5,6])

s2=s.intersection(s1)
#顯示交集
print("顯示交集")

比較簡單,這裏不再囉嗦,直接給出結果。

初始化一個重複集合
{1, 2, 3}
添加11,和1 ,打印看結果
{1, 2, 3, 4}
移除1
{2, 3, 4}
顯示交集
{3, 4}

其它集合計算方法請參考下面列表

集合內置方法完整列表

方法 描述
add() 爲集合添加元素
clear() 移除集合中的所有元素
copy() 拷貝一個集合
difference() 返回多個集合的差集
difference_update() 移除集合中的元素,該元素在指定的集合也存在。
discard() 刪除集合中指定的元素
intersection() 返回集合的交集
intersection_update() 返回集合的交集。
isdisjoint() 判斷兩個集合是否包含相同的元素,如果沒有返回 True,否則返回 False。
issubset() 判斷指定集合是否爲該方法參數集合的子集。
issuperset() 判斷該方法的參數集合是否爲指定集合的子集
pop() 隨機移除元素
remove() 移除指定元素
symmetric_difference() 返回兩個集合中不重複的元素集合。
symmetric_difference_update() 移除當前集合中在另外一個指定集合相同的元素,並將另外一個指定集合中不同的元素插入到當前集合中。
union() 返回兩個集合的並集
update() 給集合添加元素

本文是“明哥陪你學Python”系列章節之一,如果你對Python有更多興趣,或有問題,可以私信與明哥聯繫,我會陪你一起解決,其它相關章節可以從首頁中的“明哥陪你學Python”列表進行查看。

本系列教程及源碼地址:點擊訪問

最後:如果你正在學習Python的路上,或者準備打算學習Python、明哥會陪着你陪你一起共同進步!

手打不易,有用的話,請記得關注轉發。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章