欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

跟老齊學(xué)Python之字典,你還記得嗎?

 更新時(shí)間:2014年09月20日 16:49:43   投稿:hebedich  
在python中,也有一種數(shù)據(jù)與此相近,不僅相近,這種數(shù)據(jù)的名稱就叫做dictionary,翻譯過來是字典,類似于前面的int/str/list,這種類型數(shù)據(jù)名稱是:dict

字典,這個(gè)東西你現(xiàn)在還用嗎?隨著網(wǎng)絡(luò)的發(fā)展,用的人越來越少了。不少人習(xí)慣于在網(wǎng)上搜索,不僅有web版,乃至于已經(jīng)有手機(jī)版的各種字典了。我曾經(jīng)用過一本小小的《新華字典》。

《新華字典》是中國第一部現(xiàn)代漢語字典。最早的名字叫《伍記小字典》,但未能編纂完成。自1953年,開始重編,其凡例完全采用《伍記小字典》。從1953年開始出版,經(jīng)過反復(fù)修訂,但是以1957年商務(wù)印書館出版的《新華字典》作為第一版。原由新華辭書社編寫,1956年并入中科院語言研究所(現(xiàn)中國社科院語言研究所)詞典編輯室。新華字典由商務(wù)印書館出版。歷經(jīng)幾代上百名專家學(xué)者10余次大規(guī)模的修訂,重印200多次。成為迄今為止世界出版史上最高發(fā)行量的字典。
這里講到字典,不是為了敘舊。而是提醒看官想想我們?nèi)绾问褂米值洌合炔樗饕ú还苁瞧匆暨€是偏旁查字),然后通過索引找到相應(yīng)內(nèi)容。

這種方法能夠快捷的找到目標(biāo)。

在python中,也有一種數(shù)據(jù)與此相近,不僅相近,這種數(shù)據(jù)的名稱就叫做dictionary,翻譯過來是字典,類似于前面的int/str/list,這種類型數(shù)據(jù)名稱是:dict

依據(jù)管理,要知道如何建立dict和它有關(guān)屬性方法。

因?yàn)橐呀?jīng)有了此前的基礎(chǔ),所以,學(xué)這個(gè)就可以加快了。

前面曾經(jīng)建議看官一個(gè)很好的學(xué)習(xí)探究方法,比如想了解str的有關(guān)屬性方法,可以在交互模式下使用:

復(fù)制代碼 代碼如下:

>>>help(str)

將得到所有的有關(guān)內(nèi)容。

現(xiàn)在換一個(gè),使用dir,也能得到相同的結(jié)果。只是簡單一些罷了。請?jiān)诮换ツJ较拢?/p>

>>> dir(dict)
['__class__', '__cmp__', '__contains__', '__delattr__', '__delitem__', '__doc__', '__eq__', '__format__', '__ge__', '__getattribute__', '__getitem__', '__gt__', '__hash__', '__init__', '__iter__', '__le__', '__len__', '__lt__', '__ne__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__setitem__', '__sizeof__', '__str__', '__subclasshook__', 'clear', 'copy', 'fromkeys', 'get', 'has_key', 'items', 'iteritems', 'iterkeys', 'itervalues', 'keys', 'pop', 'popitem', 'setdefault', 'update', 'values', 'viewitems', 'viewkeys', 'viewvalues']


以__(雙下劃線)開頭的先不管。看后面的。如果要想深入了解,可以這樣:

復(fù)制代碼 代碼如下:

>>> help(dict.values)

然后出現(xiàn):

復(fù)制代碼 代碼如下:

Help on method_descriptor:

values(...)
    D.values() -> list of D's values
(END)


也就是在這里顯示出了values這個(gè)內(nèi)置函數(shù)的使用方法。敲擊鍵盤上的q鍵退回。

概述

python中的dict具有如下特點(diǎn):

dict是可變的
dict可以存儲(chǔ)任意數(shù)量的Python對象
dict可以存儲(chǔ)任何python數(shù)據(jù)類型
dict以:key:value,即“鍵:值”對的形式存儲(chǔ)數(shù)據(jù),每個(gè)鍵是唯一的。
dict也被稱為關(guān)聯(lián)數(shù)組或哈希表。
以上諸條,如果還不是很理解,也沒有關(guān)系,通過下面的學(xué)習(xí),特別是通過各種實(shí)驗(yàn),就能理解了。

創(chuàng)建dict

話說創(chuàng)建dict的方法可是遠(yuǎn)遠(yuǎn)多于前面的int/str/list,為什么會(huì)多呢?一般規(guī)律是復(fù)雜點(diǎn)的東西都會(huì)有多種渠道生成,這也是從安全便捷角度考慮吧。

方法1:

創(chuàng)建一個(gè)空的dict,這個(gè)空dict,可以在以后向里面加?xùn)|西用。

復(fù)制代碼 代碼如下:

>>> mydict = {}
>>> mydict
{}

創(chuàng)建有內(nèi)容的dict。

復(fù)制代碼 代碼如下:

>>> person = {"name":"qiwsir","site":"qiwsir.github.io","language":"python"}
>>> person
{'name': 'qiwsir', 'language': 'python', 'site': 'qiwsir.github.io'}

"name":"qiwsir"就是一個(gè)鍵值對,前面的name叫做鍵(key),后面的qiwsir是前面的鍵所對應(yīng)的值(value)。在一個(gè)dict中,鍵是唯一的,不能重復(fù);值則是對應(yīng)于鍵,值可以重復(fù)。鍵值之間用(:)英文的分號(hào),每一對鍵值之間用英文的逗號(hào)(,)隔開。

復(fù)制代碼 代碼如下:

>>> person['name2']="qiwsir"    #這是一種向dict中增加鍵值對的方法
>>> person
{'name2': 'qiwsir', 'name': 'qiwsir', 'language': 'python', 'site': 'qiwsir.github.io'}

如下,演示了從一個(gè)空的dict開始增加內(nèi)容的過程:

>>> mydict = {}
>>> mydict
{}
>>> mydict["site"] = "qiwsir.github.io"
>>> mydict[1] = 80
>>> mydict[2] = "python"
>>> mydict["name"] = ["zhangsan","lisi","wangwu"]
>>> mydict
{1: 80, 2: 'python', 'site': 'qiwsir.github.io', 'name': ['zhangsan', 'lisi', 'wangwu']}

>>> mydict[1] = 90 #如果這樣,則是修改這個(gè)鍵的值
>>> mydict
{1: 90, 2: 'python', 'site': 'qiwsir.github.io', 'name': ['zhangsan', 'lisi', 'wangwu']}

方法2:

>>> name = (["first","Google"],["second","Yahoo"])   #這是另外一種數(shù)據(jù)類型,稱之為元組,后面會(huì)講到
>>> website = dict(name)
>>> website
{'second': 'Yahoo', 'first': 'Google'}

方法3:

這個(gè)方法,跟上面的不同在于使用fromkeys

>>> website = {}.fromkeys(("third","forth"),"facebook")
>>> website
{'forth': 'facebook', 'third': 'facebook'}

需要提醒的是,這種方法是從新建立一個(gè)dict。

訪問dict的值

因?yàn)閐ict是以鍵值對的形式存儲(chǔ)數(shù)據(jù)的,所以,只要知道鍵,就能得到值。這本質(zhì)上就是一種映射關(guān)系。

>>> person
{'name2': 'qiwsir', 'name': 'qiwsir', 'language': 'python', 'site': 'qiwsir.github.io'}
>>> person['name']
'qiwsir'
>>> person['language']
'python'
>>> site = person['site']
>>> print site
qiwsir.github.io

如同前面所講,通過鍵能夠增加dict中的值,通過鍵能夠改變dict中的值,通過鍵也能夠訪問dict中的值。

看官可以跟list對比一下。如果我們訪問list中的元素,可以通過索引值得到(list[i]),如果是讓機(jī)器來巡回訪問,就可以用for語句。復(fù)習(xí)一下:

>>> person_list = ["qiwsir","Newton","Boolean"]  
>>> for name in person_list:
...   print name
... 
qiwsir
Newton
Boolean

那么,dict是不是也可以用for語句來循環(huán)訪問呢?當(dāng)然可以,來看例子:

>>> person
{'name2': 'qiwsir', 'name': 'qiwsir', 'language': 'python', 'site': 'qiwsir.github.io'}
>>> for key in person:
...   print person[key]
... 
qiwsir
qiwsir
python
qiwsir.github.io

知識(shí)

什么是關(guān)聯(lián)數(shù)組?以下解釋來自維基百科

在計(jì)算機(jī)科學(xué)中,關(guān)聯(lián)數(shù)組(英語:Associative Array),又稱映射(Map)、字典(Dictionary)是一個(gè)抽象的數(shù)據(jù)結(jié)構(gòu),它包含著類似于(鍵,值)的有序?qū)ΑR粋€(gè)關(guān)聯(lián)數(shù)組中的有序?qū)梢灾貜?fù)(如C++中的multimap)也可以不重復(fù)(如C++中的map)。
這種數(shù)據(jù)結(jié)構(gòu)包含以下幾種常見的操作:

1.向關(guān)聯(lián)數(shù)組添加配對
2.從關(guān)聯(lián)數(shù)組內(nèi)刪除配對
3.修改關(guān)聯(lián)數(shù)組內(nèi)的配對
4.根據(jù)已知的鍵尋找配對
字典問題是設(shè)計(jì)一種能夠具備關(guān)聯(lián)數(shù)組特性的數(shù)據(jù)結(jié)構(gòu)。解決字典問題的常用方法,是利用散列表,但有些情況下,也可以直接使用有地址的數(shù)組,或二叉樹,和其他結(jié)構(gòu)。
許多程序設(shè)計(jì)語言內(nèi)置基本的數(shù)據(jù)類型,提供對關(guān)聯(lián)數(shù)組的支持。而Content-addressable memory則是硬件層面上實(shí)現(xiàn)對關(guān)聯(lián)數(shù)組的支持。
什么是哈希表?關(guān)于哈希表的敘述比較多,這里僅僅截取了概念描述,更多的可以到維基百科上閱讀。

散列表(Hash table,也叫哈希表),是根據(jù)關(guān)鍵字(Key value)而直接訪問在內(nèi)存存儲(chǔ)位置的數(shù)據(jù)結(jié)構(gòu)。也就是說,它通過把鍵值通過一個(gè)函數(shù)的計(jì)算,映射到表中一個(gè)位置來訪問記錄,這加快了查找速度。這個(gè)映射函數(shù)稱做散列函數(shù),存放記錄的數(shù)組稱做散列表。

相關(guān)文章

最新評論