Python 字典(Dictionary)詳細介紹
字典是另一種可變容器模型,且可存儲任意類型對象。
字典的每個鍵值 key=>value 對用冒號 : 分割,每個鍵值對之間用逗號 , 分割,整個字典包括在花括號 {} 中
格式如下所示:
d = {key1 : value1, key2 : value2 }
註意:dict 作為 Python 的關鍵字和內置函數,變量名不建議命名為 dict。
鍵一般是唯一的,如果重復最後的一個鍵值對會替換前面的,值不需要唯一。
>>> tinydict = {'a': 1, 'b': 2, 'b': '3'} >>> tinydict['b'] '3' >>> tinydict {'a': 1, 'b': '3'}
值可以取任何數據類型,但鍵必須是不可變的,如字符串,數字或元組。
一個簡單的字典實例:
tinydict = {'Alice': '2341', 'Beth': '9102', 'Cecil': '3258'}
也可如此創建字典:
tinydict1 = { 'abc': 456 } tinydict2 = { 'abc': 123, 98.6: 37 }
1.訪問字典裡的值
把相應的鍵放入熟悉的方括弧,如下實例:
實例:
tinydict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'} print "tinydict['Name']: ", tinydict['Name'] print "tinydict['Age']: ", tinydict['Age']
以上實例輸出結果:
tinydict['Name']: Zara
tinydict['Age']: 7
如果用字典裡沒有的鍵訪問數據,會輸出錯誤如下:
實例:
tinydict = {'Name': 'Runoob', 'Age': 7, 'Class': 'First'} print "tinydict['Alice']: ", tinydict['Alice']
以上實例輸出結果:
tinydict['Alice']: Traceback (most recent call last): File "test.py", line 5, in <module> print "tinydict['Alice']: ", tinydict['Alice'] KeyError: 'Alice'
2.修改字典
向字典添加新內容的方法是增加新的鍵/值對,修改或刪除已有鍵/值對如下實例:
實例:
tinydict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'} tinydict['Age'] = 8 # 更新 tinydict['School'] = "RUNOOB" # 添加 print "tinydict['Age']: ", tinydict['Age'] print "tinydict['School']: ", tinydict['School']
以上實例輸出結果:
tinydict['Age']: 8 tinydict['School']: RUNOOB
3.刪除字典元素
能刪單一的元素也能清空字典,清空隻需一項操作。
顯示刪除一個字典用del命令,如下實例:
實例:
tinydict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'} del tinydict['Name'] # 刪除鍵是'Name'的條目 tinydict.clear() # 清空字典所有條目 del tinydict # 刪除字典 print "tinydict['Age']: ", tinydict['Age'] print "tinydict['School']: ", tinydict['School']
但這會引發一個異常,因為用del後字典不再存在:
tinydict['Age']: Traceback (most recent call last): File "test.py", line 10, in <module> print "tinydict['Age']: ", tinydict['Age'] NameError: name 'tinydict' is not defined
註:del()
方法後面也會討論。
3.1字典鍵的特性
字典值可以沒有限制地取任何 python
對象,既可以是標準的對象,也可以是用戶定義的,但鍵不行。
兩個重要的點需要記住:
- 1)不允許同一個鍵出現兩次。創建時如果同一個鍵被賦值兩次,後一個值會被記住,
如下實例:
tinydict = {'Name': 'Runoob', 'Age': 7, 'Name': 'Manni'} print "tinydict['Name']: ", tinydict['Name']
以上實例輸出結果:
tinydict['Name']: Manni
- 2)鍵必須不可變,所以可以用數字,字符串或元組充當,所以用列表就不行,
如下實例:
tinydict = {['Name']: 'Zara', 'Age': 7} print "tinydict['Name']: ", tinydict['Name']
以上實例輸出結果:
Traceback (most recent call last):
File "test.py", line 3, in <module>
tinydict = {['Name']: 'Zara', 'Age': 7}
TypeError: unhashable type: 'list'
4.字典內置函數&方法
Python字典包含瞭以下內置函數:
序號 | 函數及描述 |
---|---|
1 | cmp(dict1, dict2)比較兩個字典元素。 |
2 | len(dict)計算字典元素個數,即鍵的總數。 |
3 | str(dict)輸出字典可打印的字符串表示。 |
4 | type(variable)返回輸入的變量類型,如果變量是字典就返回字典類型。 |
Python字典包含瞭以下內置方法:
序號 | 函數及描述 |
---|---|
1 | dict.clear()刪除字典內所有元素 |
2 | dict.copy()返回一個字典的淺復制 |
3 | dict.fromkeys(seq[, val])創建一個新字典,以序列 seq 中元素做字典的鍵,val 為字典所有鍵對應的初始值 |
4 | dict.get(key, default=None)返回指定鍵的值,如果值不在字典中返回default值 |
5 | dict.has_key(key)如果鍵在字典dict裡返回true,否則返回false |
6 | dict.items()以列表返回可遍歷的(鍵, 值) 元組數組 |
7 | dict.keys()以列表返回一個字典所有的鍵 |
8 | dict.setdefault(key, default=None)和get()類似, 但如果鍵不存在於字典中,將會添加鍵並將值設為default |
9 | dict.update(dict2)把字典dict2的鍵/值對更新到dict裡 |
10 | dict.values()以列表返回字典中的所有值 |
11 | pop(key[,default])刪除字典給定鍵 key 所對應的值,返回值為被刪除的值。key值必須給出。 否則,返回default值。 |
12 | popitem()返回並刪除字典中的最後一對鍵和值。 |
到此這篇關於Python 字典(Dictionary)詳細介紹的文章就介紹到這瞭,更多相關Python 字典(Dictionary)內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!