python字典

本篇將介紹Python里面的字典,更多內(nèi)容請參考:Python學(xué)習(xí)指南

Python是什么屡谐?

Python內(nèi)置了字典dict的支持愕掏,dict全稱dictionary饵撑,在其他語言中也稱為map滑潘,使用鍵-值對(key-value)存儲锨咙,具有極快的查找速度酪刀。
舉個例子眼滤,假設(shè)要根據(jù)同學(xué)的名字查找對應(yīng)的成績历涝,如果用list實現(xiàn)诅需,需要兩個list:

>>>names = ['Michael', 'Bob', 'Tracy']
>>>scores = [95, 75, 85]

給定一個名字,要查找相應(yīng)的速度荧库,就先要在names中找到相應(yīng)的位置堰塌,再從scores中取出對應(yīng)的成績,list越長分衫,耗時越長场刑,明顯不是一種很好的解決方法。
如果用dict實現(xiàn)丐箩,只需要一個"名字-成績"的對照表摇邦,直接根據(jù)名字查找成績,無論這個表有多大屎勘,查找速度都不會變慢施籍。用Python寫一個dict如下:

>>>d = {"Michael": 95}
>>>d['Michael']

為什么dict查找速度這么快?因為dict的實現(xiàn)原理和查字典是一樣的概漱。假設(shè)字典包含了1萬個漢字竿裂,我們要查某一個字,一個辦法是把字典從第一頁往后翻,知道找到我們想要的字為止矫户,這種方法就是list中查找元素的方法驱闷,list越大鼓蜒,查找越慢畅厢。
第二種方法時先在字典的索引表里(比如部首表)查這個字對應(yīng)的頁碼袖肥,然后直接翻到該頁,找到這個字。無論找哪個字,這種查找速度都非衬窀ǎ快再层,不會隨著字典大小的增加而編碼烤镐。
dict的第二種實現(xiàn)方式,給定一個名字,比如'Michael',dict在內(nèi)部就可以直接計算出Michael對應(yīng)的存放成績的"頁碼"矩距,也就是95這個數(shù)字存放的內(nèi)存地址,直接取出來,所以速度非常快总棵。
你可以猜到,這種key-value存儲方式专酗,在放進(jìn)去的時候拜轨,必須根據(jù)key算出value的存放位置,這樣,取的時候才能根據(jù)key直接拿到value停撞。

注意:dict的鍵必須是唯一的横堡,但值則不必,鍵必須是不可變的樱报,如字符串迹蛤,數(shù)字或元祖箩兽。

字典的操作

字典的增刪改查

字典的創(chuàng)建

#創(chuàng)建一個字典key:value形式落包,每個鍵值對之間以','分隔
dict = {'Alice':'2341', 'Beth':'9102', 'Cecil':'3258'}
#因為dict是可變的警绩,也可以創(chuàng)建一個空的字典
dict = {}

字典的取值
字典的取值類似于列表松申,只不過列表是把鍵放入方括弧中,而列表放的是列表的下標(biāo)俯逾。

>>>dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'}
>>>print "dict['Name']: ", dict['Name']
dict['Name']:Zare
>>>print "dict['Age']: ", dict['Age']
dict['Age']:7

#如果字典中沒有對應(yīng)鍵贸桶,就會報如下錯誤
Traceback (most recent call last):
  File "test.py", line 5, in <module>
    print "dict['Alice']: ", dict['Alice'];
KeyError: 'Alice'

修改字典元素

>>>dict = {'Name': 'Zara', 'Age': 7, 'Class': 'First'};
>>>dict['Age'] = 8; # 鍵存在就更新
>>>dict['School'] = "DPS School"; # 鍵不存在就新增
>>>dict
{'Name': 'Zara', 'Age': 8, 'Class': 'First',"School": "DPS School"}

刪除字典元素
能刪除單一的元素也能清空字典,清空只需一項操作桌肴。
顯示刪除一個字典用del命令皇筛,如下實例:

dict = {"Name":"Zara", "Age":7, "Class":"First"}
del dict['Name']  #刪除鍵是'Name'的條目
dict.clear()      #清空字典所有條目
del dict          #刪除字典
#注意:使用del以后字典結(jié)構(gòu)都不存在,會報個錯坠七。
dict['Age']
Traceback (most recent call last):
  File "test.py", line 8, in <module>
    print "dict['Age']: ", dict['Age'];
TypeError: 'type' object is unsubscriptable

字典的查詢

遍歷字典主鍵與鍵值

>>>nameinfo{"a1":"yangrong"}
>>>for k, value in nameinfo.items():
        print k,value
a1 yangrong

查看字典所有主鍵

>>>dict = {'ob1':'computer','ob2':'mouse', 'ob3':'printer'}
>>>dict.keys()
['ob2', 'ob3', 'ob1']
>>> for k in d.keys():
        print dict[k]

判斷字典中是否有該主鍵

>>>dict.keys()
['ob2', 'ob3', 'ob1']
>>>dict.has_key('ob2')    #或者'ob2' in dict

查看字典里所有鍵值內(nèi)容

>>>dict = {'ob1':"computer", "ob2":"mouse", "ob3":"printer"}
>>>dict.values()
['mouse', 'printer', 'computer']

列出所有項目

>>>dict.items()
[('ob2','mouse'), ('ob3', 'printer'), ('ob1', 'computer')]

拷貝字典

>>> dict = {'ob1': "12", "ob2":"asdf", "ob3":"asdf"}
>>> 'ob1' in dict
True
>>> a = dict.copy()
>>> id(a)
35455592L
>>> id(dict)
30770040L
>>> a['ob1'] = "chenqi"
>>> dict
{'ob2': 'asdf', 'ob3': 'asdf', 'ob1': '12'}
>>> a
{'ob2': 'asdf', 'ob3': 'asdf', 'ob1': 'chenqi'}
>>>

拷貝的兩個字典不是指向同一塊內(nèi)存區(qū)水醋。

合并兩個字典

dict1={1:[1,11,111],2:[2,22,222]}
dict2={3:[3,33,333],4:[4,44,444]}

#方法一
dictMerged1=dict(dict1.items()+dict2.items())

#方法二
dictMerged2=dict(dict1, **dict2)

#方法二等同于
dictMerged=dict1.copy()
dictMerged.update(dict2)

Python內(nèi)置函數(shù)&方法

Python字典包含了以下內(nèi)置函數(shù):

  1. cmp(dict1, dict2):比較兩個字典元素。
  2. len(dict):計算字典元素個數(shù)彪置,即鍵的總數(shù)拄踪。
  3. str(dict):輸出字典可打印的字符串表示。
  4. type(variable):返回輸入的變量類型拳魁,如果變量是字典就返回字典類型惶桐。

Python字典包含了以下內(nèi)置方法:

  1. radiansdict.clear():刪除字典內(nèi)所有元素
  2. radiansdict.copy():返回一個字典的淺復(fù)制,關(guān)于Python的深拷貝潘懊、淺拷貝參考Python 直接賦值姚糊、淺拷貝和深度拷貝解析
  3. radiansdict.fromkeys():創(chuàng)建一個新字典,以序列seq中元素做字典的鍵授舟,val為字典所有鍵對應(yīng)的初始值
  4. radiansdict.get(key, default=None):返回指定鍵的值救恨,如果值不在字典中返回default值
  5. radiansdict.has_key(key):如果鍵在字典dict里返回true,否則返回false(python3中已經(jīng)去掉了释树,使用in更符合python)
  6. radiansdict.items():以列表返回可遍歷的(鍵, 值) 元組數(shù)組
  7. radiansdict.keys():以列表返回一個字典所有的鍵
  8. radiansdict.setdefault(key, default=None):和get()類似, 但如果鍵不已經(jīng)存在于字典中肠槽,將會添加鍵并將值設(shè)為default
  9. radiansdict.update(dict2):把字典dict2的鍵/值對更新到dict里
  10. radiansdict.values():以列表返回字典中的所有值
  11. radiansdict.popitem():Python 字典 popitem() 方法隨機返回并刪除字典中的一對鍵和值(一般刪除末尾對)。
    如果字典已經(jīng)為空奢啥,卻調(diào)用了此方法署浩,就報出KeyError異常。
  12. radiansdict.pop(key[,default]):Python 字典 pop() 方法刪除字典給定鍵 key 所對應(yīng)的值扫尺,返回值為被刪除的值。key值必須給出炊汤。 否則正驻,返回default值弊攘。

參考

  1. Python 字典(Dictionary)
  2. python_字典集合
  3. 廖雪峰(dict與set)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市姑曙,隨后出現(xiàn)的幾起案子襟交,更是在濱河造成了極大的恐慌,老刑警劉巖伤靠,帶你破解...
    沈念sama閱讀 217,185評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件捣域,死亡現(xiàn)場離奇詭異,居然都是意外死亡宴合,警方通過查閱死者的電腦和手機焕梅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,652評論 3 393
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來卦洽,“玉大人贞言,你說我怎么就攤上這事》У伲” “怎么了该窗?”我有些...
    開封第一講書人閱讀 163,524評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長蚤霞。 經(jīng)常有香客問我酗失,道長,這世上最難降的妖魔是什么昧绣? 我笑而不...
    開封第一講書人閱讀 58,339評論 1 293
  • 正文 為了忘掉前任规肴,我火速辦了婚禮,結(jié)果婚禮上滞乙,老公的妹妹穿的比我還像新娘奏纪。我一直安慰自己,他們只是感情好斩启,可當(dāng)我...
    茶點故事閱讀 67,387評論 6 391
  • 文/花漫 我一把揭開白布序调。 她就那樣靜靜地躺著,像睡著了一般兔簇。 火紅的嫁衣襯著肌膚如雪发绢。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,287評論 1 301
  • 那天垄琐,我揣著相機與錄音边酒,去河邊找鬼。 笑死狸窘,一個胖子當(dāng)著我的面吹牛墩朦,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播翻擒,決...
    沈念sama閱讀 40,130評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼氓涣,長吁一口氣:“原來是場噩夢啊……” “哼牛哺!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起劳吠,我...
    開封第一講書人閱讀 38,985評論 0 275
  • 序言:老撾萬榮一對情侶失蹤引润,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后痒玩,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體淳附,經(jīng)...
    沈念sama閱讀 45,420評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,617評論 3 334
  • 正文 我和宋清朗相戀三年蠢古,在試婚紗的時候發(fā)現(xiàn)自己被綠了奴曙。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,779評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡便瑟,死狀恐怖缆毁,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情到涂,我是刑警寧澤脊框,帶...
    沈念sama閱讀 35,477評論 5 345
  • 正文 年R本政府宣布,位于F島的核電站践啄,受9級特大地震影響浇雹,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜屿讽,卻給世界環(huán)境...
    茶點故事閱讀 41,088評論 3 328
  • 文/蒙蒙 一昭灵、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧伐谈,春花似錦烂完、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,716評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至履澳,卻和暖如春嘶窄,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背距贷。 一陣腳步聲響...
    開封第一講書人閱讀 32,857評論 1 269
  • 我被黑心中介騙來泰國打工柄冲, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人忠蝗。 一個月前我還...
    沈念sama閱讀 47,876評論 2 370
  • 正文 我出身青樓现横,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子长赞,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,700評論 2 354

推薦閱讀更多精彩內(nèi)容

  • 一晦攒、字典基本操作 基本語法:dict = {'ob1':'computer', 'ob2':'mouse', 'o...
    古佛青燈度流年閱讀 2,637評論 0 1
  • 字典dict python內(nèi)置了字典,使用鍵-值(key-value)存儲得哆。鍵必須是唯一的,但值則不必哟旗。特點是速度...
    光刃小刀閱讀 2,257評論 0 0
  • 1 字典基礎(chǔ)操作 1.1 創(chuàng)建字典 通過{}操作符創(chuàng)建字典aDict = {'name':'ke', 'age':...
    Ke爺閱讀 580評論 0 0
  • 1. 簡介 只有可散列的數(shù)據(jù)類型才能作為字典的鍵贩据,原子不可變數(shù)據(jù)類型(str、bytes 和數(shù)值類型)都是可散列類...
    第八共同體閱讀 325評論 0 0
  • 小強晚上和兩個同事一起下館子闸餐。公司處于比較偏僻的開發(fā)區(qū)饱亮,周圍比較荒涼。好在公司內(nèi)部有宿舍舍沙,上班比較方便近上。平時大家也...
    蘆說閱讀 430評論 3 0