Python3 字典
字典是另一種可變容器模型,且可存儲任意類型對象。
Python3中的字典是一種無序、可變、可迭代的數據結構,它由鍵(key)和對應的值(value)組成。字典在Python中被視為可變對象,這意味著我們可以隨時更改、添加或刪除字典中的元素。
以下是一些關于Python3字典的基本特性:
- 鍵和值:字典中的每個元素都由一個鍵和一個值組成。鍵是唯一的,每個鍵只能對應一個值。鍵和值之間用冒號分隔,而鍵值對之間用逗號分隔。
- 無序:字典是無序的,這意味著當你創建一個字典時,元素的順序可能會隨著時間的推移而改變。在Python3.7及以后的版本中,字典是按照插入順序進行排序的,但這不是一個保證。
- 可變性:Python字典是可變的,這意味著你可以在已有的字典中添加、刪除或更改元素。
- 遍歷:可以通過循環遍歷字典中的所有鍵和值。
- 內置函數和方法:Python字典有許多內置的函數和方法,如get(), keys(), values(), items()等,這些可以幫助你更好地操作和使用字典。
字典的每個鍵值 key=>value 對用冒號 : 分割,每個對之間用逗號(,)分割,整個字典包括在花括號 {} 中 ,格式如下所示:
d = {key1 : value1, key2 : value2, key3 : value3 }
注意:dict 作為 Python 的關鍵字和內置函數,變量名不建議命名為 dict。
-
鍵必須是唯一的,但值則不必。
-
值可以取任何數據類型,但鍵必須是不可變的,如字符串,數字。
一個簡單的字典實例:
tinydict = {'name': 'tarzan', 'likes': 666, 'url': 'www.tarzan.com'}
也可如此創建字典:
tinydict1 = { 'abc': 456 }
tinydict2 = { 'abc': 123, 98.6: 37 }
創建空字典
使用大括號 { } 創建空字典:
實例:
# 使用大括號 {} 來創建空字典
emptyDict = {}# 打印字典
print(emptyDict)# 查看字典的數量
print("Length:", len(emptyDict))# 查看類型
print(type(emptyDict))
以上實例輸出結果:
{}
Length: 0
<class ‘dict’>
使用內建函數 dict() 創建字典:
實例
emptyDict = dict()
# 打印字典
print(emptyDict)
# 查看字典的數量
print("Length:",len(emptyDict))
# 查看類型
print(type(emptyDict))
以上實例輸出結果:
{}
Length: 0
<class ‘dict’>
訪問字典里的值
把相應的鍵放入到方括號中,如下實例:
#!/usr/bin/python3tinydict = {'Name': 'Tarzan', 'Age': 7, 'Class': 'First'}print ("tinydict['Name']: ", tinydict['Name'])
print ("tinydict['Age']: ", tinydict['Age'])
實例
以上實例輸出結果:
tinydict[‘Name’]: Tarzan
tinydict[‘Age’]: 7
如果用字典里沒有的鍵訪問數據,會輸出錯誤如下:
#!/usr/bin/python3tinydict = {'Name': 'Tarzan', 'Age': 7, 'Class': 'First'}print ("tinydict['Alice']: ", tinydict['Alice'])
以上實例輸出結果:
Traceback (most recent call last):File "test.py", line 5, in <module>print ("tinydict['Alice']: ", tinydict['Alice'])
KeyError: 'Alice'
修改字典
向字典添加新內容的方法是增加新的鍵/值對,修改或刪除已有鍵/值對如下實例:
#!/usr/bin/python3tinydict = {'Name': 'Tarzan', 'Age': 7, 'Class': 'First'}tinydict['Age'] = 8 # 更新 Age
tinydict['School'] = "泰山教程" # 添加信息print ("tinydict['Age']: ", tinydict['Age'])
print ("tinydict['School']: ", tinydict['School'])
以上實例輸出結果:
tinydict['Age']: 8
tinydict['School']: 菜鳥教程
刪除字典元素
能刪單一的元素也能清空字典,清空只需一項操作。
顯式刪除一個字典用del命令,如下實例:
#!/usr/bin/python3tinydict = {'Name': 'Tarzan', 'Age': 7, 'Class': 'First'}del tinydict['Name'] # 刪除鍵 'Name'
tinydict.clear() # 清空字典
del tinydict # 刪除字典print ("tinydict['Age']: ", tinydict['Age'])
print ("tinydict['School']: ", tinydict['School'])
但這會引發一個異常,因為用執行 del 操作后字典不再存在:
Traceback (most recent call last):File "/runoob-test/test.py", line 9, in <module>print ("tinydict['Age']: ", tinydict['Age'])
NameError: name 'tinydict' is not defined
注:del() 方法后面也會討論。
字典鍵的特性
字典值可以是任何的 python 對象,既可以是標準的對象,也可以是用戶定義的,但鍵不行。
兩個重要的點需要記住:
- 不允許同一個鍵出現兩次。創建時如果同一個鍵被賦值兩次,后一個值會被記住,如下實例:
#!/usr/bin/python3tinydict = {'Name': 'Tarzan', 'Age': 7, 'Name': '小菜鳥'}print ("tinydict['Name']: ", tinydict['Name'])
以上實例輸出結果:
tinydict[‘Name’]: 小菜鳥
- 鍵必須不可變,所以可以用數字,字符串或元組充當,而用列表就不行,如下實例:
#!/usr/bin/python3tinydict = {['Name']: 'Tarzan', 'Age': 7}print ("tinydict['Name']: ", tinydict['Name'])
以上實例輸出結果:
Traceback (most recent call last):File "test.py", line 3, in <module>tinydict = {['Name']: 'Runoob', 'Age': 7}
TypeError: unhashable type: 'list'
字典內置函數&方法
Python字典包含了以下內置函數:
函數 | 描述 | 實例 |
---|---|---|
len(dict) | 計算字典元素個數,即鍵的總數 | >>> tinydict = {‘Name’: ‘Runoob’, ‘Age’: 7, ‘Class’: ‘First’} >>> len(tinydict) |
str(dict) | 輸出字典,可以打印的字符串表示。 | >>> tinydict = {‘Name’: ‘Runoob’, ‘Age’: 7, ‘Class’: ‘First’} >>> str(tinydict) “{‘Name’: ‘Runoob’, ‘Class’: ‘First’, ‘Age’: 7}” |
type(variable) | 返回輸入的變量類型,如果變量是字典就返回字典類型。 | >>> tinydict = {‘Name’: ‘Runoob’, ‘Age’: 7, ‘Class’: ‘First’} >>> type(tinydict) <class ‘dict’> |
dict.clear() | 刪除字典內所有元素 | |
dict.copy() | 返回一個字典的淺復制 | |
dict.fromkeys() | 創建一個新字典,以序列seq中元素做字典的鍵,val為字典所有鍵對應的初始值 | |
dict.get(key, default=None) | 返回指定鍵的值,如果鍵不在字典中返回 default 設置的默認值 | |
key in dict | 如果鍵在字典dict里返回true,否則返回false | |
dict.items() | 以列表返回一個視圖對象 | |
dict.keys() | 返回一個視圖對象 | |
dict.setdefault(key, default=None) | 和get()類似, 但如果鍵不存在于字典中,將會添加鍵并將值設為default | |
dict.update(dict2) | 把字典dict2的鍵/值對更新到dict里 | |
dict.values() | 返回一個視圖對象 | |
pop(key[,default]) | 刪除字典 key(鍵)所對應的值,返回被刪除的值。 | |
popitem() | 返回并刪除字典中的最后一對鍵和值。 |