字典是另一種可變?nèi)萜髂P?,且可存儲任意類型對象?br/>字典的每個鍵值對key-value對用冒號:分割,每個對之間用逗號,分割,整個字典包括在花括號{}中,鍵必須是唯一的,但值則不必。
值可以取任何數(shù)據(jù)類型,但鍵必須是不可變的,如字符串,數(shù)字或元組,列表集合就不可以。
創(chuàng)新互聯(lián)公司為您提適合企業(yè)的網(wǎng)站設(shè)計(jì)?讓您的網(wǎng)站在搜索引擎具有高度排名,讓您的網(wǎng)站具備超強(qiáng)的網(wǎng)絡(luò)競爭力!結(jié)合企業(yè)自身,進(jìn)行網(wǎng)站設(shè)計(jì)及把握,最后結(jié)合企業(yè)文化和具體宗旨等,才能創(chuàng)作出一份性化解決方案。從網(wǎng)站策劃到做網(wǎng)站、網(wǎng)站制作, 我們的網(wǎng)頁設(shè)計(jì)師為您提供的解決方案。
變量名 = {字典元素}
>>> dict = {'AA':'001','BB':'002','CCC':3,4:4}
>>> dict
{'AA': '001', 'BB': '002', 'CCC': 3, 4: 4}
>>> dict1 = { 'abc': 456 }
>>> dict1
{'abc': 456}
>>> dict2 = { 'abc': 123, 98.6: 37 }
>>> dict2
{'abc': 123, 98.6: 37}
字典不能像列表一樣通過索引值去訪問元素,字典查找值是把相應(yīng)的鍵放入到方括號中去訪問值。如果用字典里沒有的鍵訪問數(shù)據(jù),會報(bào)錯。
>>> dict
{'AA': '001', 'BB': '002', 'CCC': 3, 4: 4}
>>> dict['AA']
'001'
>>> dict[4]
4
>>> dict['xxx']
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
KeyError: 'xxx'
第2種方法:通過dict提供的get()方法。
如果key不存在,不會報(bào)錯也不會返回任何信息,但是也可以自己指定不存在時的返回值。
>>> dict
{'AA': 1, 'BB': '002', 'CCC': 3, 4: 4, 'DDD': 889, 'new': '新的鍵值對'}
>>> dict.get('BB')
'002'
>>> dict.get('NO')
>>> dict.get('NO',-1)
-1
>>> dict.get('NO','不存在')
'不存在'
向字典添加新內(nèi)容的方法是增加新的鍵/值對
>>> dict['DDD'] = 889
>>> dict
{'AA': '001', 'BB': '002', 'CCC': 3, 4: 4, 'DDD': 889}
>>> dict['new'] = '新的鍵值對'
>>> dict
{'AA': '001', 'BB': '002', 'CCC': 3, 4: 4, 'DDD': 889, 'new': '新的鍵值對'}
由于一個key只能對應(yīng)一個value,所以,多次對一個key放入value,后面的值會把前面的值沖掉,也就是修改了元素的值。
同樣修改不存在的鍵會報(bào)錯。
>>> dict['AA'] = 1
>>> dict
{'AA': 1, 'BB': '002', 'CCC': 3, 4: 4, 'DDD': 889, 'new': '新的鍵值對'}
del dict[key]
刪除dict字典中鍵key對應(yīng)的那對鍵值對。
>>> dict
{'AA': 1, 'BB': '002', 'CCC': 3, 4: 4, 'DDD': 889, 'new': '新的鍵值對'}
>>> del dict['AA']
>>> dict
{'BB': '002', 'CCC': 3, 4: 4, 'DDD': 889, 'new': '新的鍵值對'}
del也可以用來刪除整個字典,刪除后字典就不存在了。
>>> dict2
{'abc': 123, 98.6: 37}
>>> del dict2
>>> dict2
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
NameError: name 'dict2' is not defined #刪除后,字典不存在,訪問不存在的對象會報(bào)錯
清空字典:dict.clear()
只是刪除字典里的所有元素即鍵值對,字典仍然存在,為空字典。
>>> dict1
{'abc': 456}
>>> dict1.clear()
>>> dict1
{}
dict內(nèi)部存放的順序和key放入的順序是沒有關(guān)系的。
使用字典,再查找數(shù)據(jù)時,速度會很快。因?yàn)閐ict的實(shí)現(xiàn)原理和查漢語字典是一樣的。假設(shè)字典包含了1萬個漢字,我們要查某一個字,一個辦法是把字典從第一頁往后翻,直到找到我們想要的字為止,這種方法就是在list中查找元素的方法,list越大,查找越慢。
第二種方法是先在字典的索引表里(比如部首表)查這個字對應(yīng)的頁碼,然后直接翻到該頁,找到這個字。無論找哪個字,這種查找速度都非常快,不會隨著字典大小的增加而變慢。
dict就是第二種實(shí)現(xiàn)方式,給定一個名字,比如'Michael',dict在內(nèi)部就可以直接計(jì)算出Michael對應(yīng)的存放成績的“頁碼”,也就是95這個數(shù)字存放的內(nèi)存地址,直接取出來,所以速度非常快。
你可以猜到,這種key-value存儲方式,在放進(jìn)去的時候,必須根據(jù)key算出value的存放位置,這樣,取的時候才能根據(jù)key直接拿到value。
和list比較,dict有以下幾個特點(diǎn):
1.查找和插入的速度極快,不會隨著key的增加而變慢;
2.需要占用大量的內(nèi)存,內(nèi)存浪費(fèi)多。
而list相反:
1.查找和插入的時間隨著元素的增加而增加;
2.占用空間小,浪費(fèi)內(nèi)存很少。
所以,dict是用空間來換取時間的一種方法。
當(dāng)前題目:Python學(xué)習(xí)—字典
當(dāng)前路徑:http://jinyejixie.com/article38/podepp.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、手機(jī)網(wǎng)站建設(shè)、網(wǎng)站策劃、電子商務(wù)、域名注冊、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)