上一篇我們簡單對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、明哥會陪着你陪你一起共同進步!
手打不易,有用的話,請記得關注轉發。