字典(dict)結構是Python中常用的數據結構,筆者結合自己的實際使用經驗,對字典方面的相關知識做個小結,希望能對讀者一些啟發~
創建字典
常見的字典創建方法就是先建立一個空字典,然后逐一添加鍵(key)和值(value),比如創建字典person={'name':'Tome', 'age':22, 'city':'Shanghai, 'ID': '073569'},可以使用以下代碼:
person = {}person['name'] = 'Tom'person['age'] = 22person['city'] = 'Shanghai'person['ID'] = '073569'print(person)輸出結果為:
{'name': 'Tom', 'age': 22, 'city': 'Shanghai', 'ID': '073569'}
這樣的創建方式簡單原始,代碼不夠簡潔優雅。我們用zip函數,來簡單快捷地創建這個字典:
attrs = ['name', 'age', 'city', 'ID']values = ['Tom', 22, 'Shanghai', '073569']person = dict(zip(attrs, values))print(person)
輸出結果與原先代碼一致。
遍歷字典
在實際應用中,我們常常需要遍歷字典,實現的方法可參考以下代碼:
attrs = ['name', 'age', 'city', 'ID']values = ['Tom', 22, 'Shanghai', '073569']person = dict(zip(attrs, values))for key, value in person.items(): print('Key:%-6s, Value:%s'%(key, value))輸出結果為:
Key:name , Value:Tom
Key:age , Value:22
Key:city , Value:Shanghai
Key:ID , Value:073569
對調鍵值對
在實際應用中,有時候我們需要查找字典中某個值(value)對應的鍵(key),遍歷字典是一種選擇,對調鍵值對是另一種選擇。對調鍵值對的實現代碼如下:
attrs = ['name', 'age', 'city', 'ID']values = ['Tom', 22, 'Shanghai', '073569']person = dict(zip(attrs, values))print('對調前:')print(person)Person = {v:k for k,v in person.items()}print('對調后:')print(Person)輸出結果為:
對調前:
{'name': 'Tom', 'age': 22, 'city': 'Shanghai', 'ID': '073569'}
對調后:
{'Tom': 'name', 22: 'age', 'Shanghai': 'city', '073569': 'ID'}
有序字典OrderedDict
Python中的字典是無序的,其取出來的鍵是無序的,因為它是按照hash來儲存的。有時候,我們需要字典的條目(items)或鍵(keys)是有序儲存的,這時候可以使用collections模塊中的OrderedDict,它是一種有序的字典結構。
示例代碼如下(Python版本為3.5.2):
from collections import OrderedDictd = {}d['Tom']='A'd['Jack']='B'd['Leo']='C'd['Alex']='D'print('無序字典(dict):')for k,v in d.items(): print(k,v)d1 = OrderedDict()d1['Tom']='A'd1['Jack']='B'd1['Leo']='C'd1['Alex']='D'print('/n有序字典(OrderedDict):')for k,v in d1.items(): print(k,v)輸出的結果為:
無序字典(dict):
Leo C
Jack B
Tom A
Alex D有序字典(OrderedDict):
Tom A
Jack B
Leo C
Alex D
默認字典collections.defaultdict
collections.defaultdict是Python內建dict類的一個子類,第一個參數為default_factory屬性提供初始值,默認為None。它覆蓋一個方法并添加一個可寫實例變量。它的其他功能與dict相同,但會為一個不存在的鍵提供默認值,從而避免KeyError異常。
我們以統計列表中單詞的詞頻為例,展示collections.defaultdict的優勢。
一般情形下,我們統計列表中的單詞詞頻代碼為:
words = ['sun', 'moon', 'star', 'star',/ 'star', 'moon', 'sun', 'star']freq_dict = {}for word in words: if word not in freq_dict.keys(): freq_dict[word] = 1 else: freq_dict[word] += 1for key, val in freq_dict.items(): print(key, val)輸出結果如下:
sun 2
moon 2
star 4
使用collections.defaultdict,代碼可以優化:
from collections import defaultdictwords = ['sun', 'moon', 'star', 'star',/ 'star', 'moon', 'sun', 'star']freq_dict = defaultdict(int)for word in words: freq_dict[word] += 1for key, val in freq_dict.items(): print(key, val)
其它默認初始值可以為set,list,dict等。
訪問字典里的值
把相應的鍵放入熟悉的方括弧,如下實例:
dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'};print "dict['Name']: ", dict['Name'];print "dict['Age']: ", dict['Age'];#以上實例輸出結果:#dict['Name']: Zara#dict['Age']: 7如果用字典里沒有的鍵訪問數據,會輸出錯誤如下:
dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'};print "dict['Alice']: ", dict['Alice'];以上實例輸出結果:
#KeyError: 'Alice'[/code]
修改字典
向字典添加新內容的方法是增加新的鍵/值對,修改或刪除已有鍵/值對如下實例:
dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'};dict['Age'] = 8; # update existing entrydict['School'] = "DPS School"; # Add new entry print "dict['Age']: ", dict['Age'];print "dict['School']: ", dict['School'];#以上實例輸出結果:#dict['Age']: 8#dict['School']: DPS School刪除字典元素
能刪單一的元素也能清空字典,清空只需一項操作。
顯示刪除一個字典用del命令,如下實例:
dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'};del dict['Name']; # 刪除鍵是'Name'的條目dict.clear(); # 清空詞典所有條目del dict ; # 刪除詞典print "dict['Age']: ", dict['Age'];print "dict['School']: ", dict['School'];#但這會引發一個異常,因為用del后字典不再存在:dict['Age']:字典內置函數&方法
Python字典包含了以下內置函數:
cmp(dict1, dict2) #比較兩個字典元素。len(dict) #計算字典元素個數,即鍵的總數。str(dict) #輸出字典可打印的字符串表示。type(variable) #返回輸入的變量類型,如果變量是字典就返回字典類型。
Python字典包含了以下內置方法:
radiansdict.clear() #刪除字典內所有元素radiansdict.copy() #返回一個字典的淺復制radiansdict.fromkeys() #創建一個新字典,以序列seq中元素做字典的鍵,val為字典所有鍵對應的初始值radiansdict.get(key, default=None) #返回指定鍵的值,如果值不在字典中返回default值radiansdict.has_key(key) #如果鍵在字典dict里返回true,否則返回falseradiansdict.items() #以列表返回可遍歷的(鍵, 值) 元組數組radiansdict.keys() #以列表返回一個字典所有的鍵radiansdict.setdefault(key, default=None) #和get()類似, 但如果鍵不已經存在于字典中,將會添加鍵并將值設為defaultradiansdict.update(dict2) #把字典dict2的鍵/值對更新到dict里radiansdict.values() #以列表返回字典中的所有值
字典練習代碼
print('''|---歡迎進入通訊錄程序---||---1、 查詢聯系人資料---||---2、 插入新的聯系人---||---3、 刪除已有聯系人---||---4、 退出通訊錄程序---|''')addressBook={}#定義通訊錄while 1: temp=input('請輸入指令代碼:') if not temp.isdigit(): print("輸入的指令錯誤,請按照提示輸入") continue item=int(temp)#轉換為數字 if item==4: print("|---感謝使用通訊錄程序---|") break name = input("請輸入聯系人姓名:") if item==1: if name in addressBook: print(name,':',addressBook[name]) continue else: print("該聯系人不存在!") if item==2: if name in addressBook: print("您輸入的姓名在通訊錄中已存在-->>",name,":",addressBook[name]) isEdit=input("是否修改聯系人資料(Y/N):") if isEdit=='Y': userphone = input("請輸入聯系人電話:") addressBook[name]=userphone print("聯系人修改成功") continue else: continue else: userphone=input("請輸入聯系人電話:") addressBook[name]=userphone print("聯系人加入成功!") continue if item==3: if name in addressBook: del addressBook[name] print("刪除成功!") continue else: print("聯系人不存在")以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VEVB武林網。
新聞熱點
疑難解答