詳解Python中映射類型的內(nèi)建函數(shù)和工廠函數(shù)
1.基本函數(shù)介紹
(1)標(biāo)準(zhǔn)類型函數(shù)[type()、str()和 cmp()]
對(duì)一個(gè)字典調(diào)用type()工廠方法,會(huì)返回字典類型:“<type 'dict'>”。調(diào)用str()工廠方法將返回該字典的字符串表示形式。
字典是通過這樣的算法來(lái)比較的:首先是字典的大小,然后是鍵,最后是值??墒怯胏mp()做字典的比較一般不是很有用。
算法按照以下的順序:
首先比較字典長(zhǎng)度
如果字典的長(zhǎng)度不同,那么用cmp(dict1, dict2)比較大小時(shí),如果字典dict1比dict2長(zhǎng),cmp()返回正值,如果dict2比dict1長(zhǎng),則返回負(fù)值。也就是說字典中的鍵的個(gè)數(shù)越多,這個(gè)字典就越大,即:len(dict1) > len(dict2) ==> dict1 > dict2。
其次比較字典的鍵
如果兩個(gè)字典的長(zhǎng)度相同,那就按字典的鍵比較。鍵比較的順序和keys()方法返回鍵的順序相同。(注意: 相同的鍵會(huì)映射到哈希表的同一位置,這保證了對(duì)字典鍵的檢查的一致性)。這時(shí),如果兩個(gè)字典的鍵不匹配時(shí),對(duì)這兩個(gè)(不匹配的鍵)直接進(jìn)行比較。當(dāng)dict1中第一個(gè)不同的鍵大于dict2中第一個(gè)不同的鍵,cmp()會(huì)返回正值。
然后比較字典的值
如果兩個(gè)字典的長(zhǎng)度相同而且它們的鍵也完全匹配,則用字典中每個(gè)相同的鍵所對(duì)應(yīng)的值進(jìn)行比較。一旦出現(xiàn)不匹配的值,就對(duì)
這兩個(gè)值進(jìn)行直接比較。若dict1比dict2中相同的鍵所對(duì)應(yīng)的值大,cmp()會(huì)返回正值。
完全匹配
到此為止,即每個(gè)字典有相同的長(zhǎng)度、相同的鍵、每個(gè)鍵也對(duì)應(yīng)相同的值,則字典完全匹配,返回 0 值。
(2)映射類型相關(guān)的函數(shù)
dict()
工廠函數(shù)被用來(lái)創(chuàng)建字典,如果不提供參數(shù)會(huì)生成空字典。當(dāng)容器類型對(duì)象做為一個(gè)參數(shù)傳遞給方法 dict(),如果參數(shù)是可以迭代的,即一個(gè)序列或是一個(gè)迭代器或是一個(gè)支持迭代的對(duì)象,那每個(gè)可迭代的元素必須成對(duì)出現(xiàn)。在每個(gè)值對(duì)中,第一個(gè)元素是字典的鍵、第二個(gè)元素是字典中的值。
>>> dict(zip(('x', 'y'), (1, 2)))
{'y': 2, 'x': 1}
>>> dict([['x', 1], ['y', 2]])
{'y': 2, 'x': 1}
>>> dict([('xy'[i-1], i) for i in range(1,3)])
{'y': 2, 'x': 1}
如果輸入?yún)?shù)是(另)一個(gè)映射對(duì)象,比如一個(gè)字典對(duì)象,對(duì)其調(diào)用dict()會(huì)從存在的字典里復(fù)制內(nèi)容來(lái)生成新的字典。新生成的字典是原來(lái)字典對(duì)象的淺復(fù)制版本,它與用字典的內(nèi)建方法copy()生成的字典對(duì)象是一樣的。但是從已存在的字典生成新的字典速度比用copy()方法慢,推薦使用copy()。
len()
內(nèi)建函數(shù)len()很靈活,它可用在序列、映射類型和集合上。對(duì)字典調(diào)用 len(),它會(huì)返回所有元素(鍵-值對(duì))的數(shù)目。
hash()
內(nèi)建函數(shù)hash()本身并不是為字典設(shè)計(jì)的方法,但它可以判斷某個(gè)對(duì)象是否可以做一個(gè)字典的鍵。將一個(gè)對(duì)象作為參數(shù)傳遞給 hash(),會(huì)返回這個(gè)對(duì)象的哈希值。 只有這個(gè)對(duì)象是可哈希的,才可作為字典的鍵 (函數(shù)的返回值是整數(shù),不產(chǎn)生錯(cuò)誤或異常)。如果用比較操作符來(lái)比較兩個(gè)數(shù)值,發(fā)現(xiàn)它們是相等的,那么即使二者的數(shù)據(jù)類型不同, 它們也會(huì)得到相同的哈希值。如果非可哈希類型作為參數(shù)傳遞給hash()方法,會(huì)產(chǎn)生TypeError錯(cuò)誤,因此如果使用這樣的對(duì)象作為鍵給字典賦值時(shí)會(huì)出錯(cuò)。
2.映射類型的內(nèi)建函數(shù)和工廠函數(shù)使用實(shí)例
標(biāo)準(zhǔn)類型函數(shù)[type(),str()和cmp()]
字典比較算法
>>> dict1 = {}
>>> dict2 = {'host':'earth','port':80}
>>> cmp(dict1,dict2)
-1
>>> dict1['host'] = 'earth'
>>> cmp(dict1,dict2)
-1
>>> dict1['port'] = 80
>>> cmp(dict1,dict2)
0
>>> dict1['port'] = 'tcp'
>>> cmp(dict1,dict2)
1
>>> dict2['port'] = 'udp'
>>> cmp(dict1,dict2)
-1
>>> cdict = {'fruits':1}
>>> ddict = {'fruits':1}
>>> cmp(cdict,ddict)
0
>>> cdict['oranges'] = 0
>>> cdict['apples'] = 0
>>> cmp(cdict,ddict)
1
映射類型相關(guān)的函數(shù)
dict()
>>> dict(zip(('x','y'),(1,2)))
{'y': 2, 'x': 1}
>>> dict([['x',1],['y',2]])
{'y': 2, 'x': 1}
>>> dict([('xy'[i-1],i) for i in range(1,3)])
{'y': 2, 'x': 1}
>>> dict(x=1,y=2)
{'y': 2, 'x': 1}
>>> dict8 = dict(x=1,y=2)
>>> dict8
{'y': 2, 'x': 1}
>>> dict9 = dict(**dict8)
>>> dict9
{'y': 2, 'x': 1}
>>> dict9 = dict8.copy()
>>> dict9
{'y': 2, 'x': 1}
len()
>>> dict2 = {'name':'earth','port':80}
>>> dict2
{'name': 'earth', 'port': 80}
>>> len(dict2)
2
- python基礎(chǔ)入門詳解(文件輸入/輸出 內(nèi)建類型 字典操作使用方法)
- Python隨手筆記之標(biāo)準(zhǔn)類型內(nèi)建函數(shù)
- Python列表list操作符實(shí)例分析【標(biāo)準(zhǔn)類型操作符、切片、連接字符、列表解析、重復(fù)操作等】
- 利用標(biāo)準(zhǔn)庫(kù)fractions模塊讓Python支持分?jǐn)?shù)類型的方法詳解
- Python標(biāo)準(zhǔn)庫(kù)之typing的用法(類型標(biāo)注)
- Python的五個(gè)標(biāo)準(zhǔn)數(shù)據(jù)類型你認(rèn)識(shí)幾個(gè)
- python內(nèi)建類型與標(biāo)準(zhǔn)類型
相關(guān)文章
Python網(wǎng)絡(luò)編程之HTTP協(xié)議的python應(yīng)用
HTTP是在網(wǎng)絡(luò)上傳輸HTML的協(xié)議,用于瀏覽器和服務(wù)器的通信,這篇文章主要介紹了Python網(wǎng)絡(luò)編程之HTTP協(xié)議的python應(yīng)用,需要的朋友可以參考下2022-11-11
一小時(shí)學(xué)會(huì)TensorFlow2之Fashion Mnist
這篇文章主要介紹了TensorFlow2之Fashion Mnist,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2021-09-09
python用BeautifulSoup庫(kù)簡(jiǎn)單爬蟲實(shí)例分析
文章給大家分享了關(guān)于python爬蟲的相關(guān)實(shí)例以及相關(guān)代碼,有興趣的朋友們參考下。2018-07-07
python實(shí)現(xiàn)的登陸Discuz!論壇通用代碼分享
這篇文章主要介紹了python實(shí)現(xiàn)的登陸Discuz!論壇通用代碼分享,需要的朋友可以參考下2014-07-07
Python 實(shí)現(xiàn)毫秒級(jí)淘寶搶購(gòu)腳本的示例代碼
本篇文章主要介紹了Python 通過selenium實(shí)現(xiàn)毫秒級(jí)自動(dòng)搶購(gòu)的示例代碼,通過掃碼登錄即可自動(dòng)完成一系列操作,搶購(gòu)時(shí)間精確至毫秒,可搶加購(gòu)物車等待時(shí)間結(jié)算的,感興趣的小伙伴們可以參考一下2019-09-09
Python打包exe時(shí)各種異常處理方案總結(jié)
今天教大家用Python打包exe時(shí)各種異常處理的方案總結(jié),下文中有非常詳細(xì)的介紹,對(duì)正在學(xué)習(xí)python的小伙伴們很有幫助喲,需要的朋友可以參考下2021-05-05
NumPy隨機(jī)數(shù)據(jù)分布與Seaborn可視化詳解
數(shù)據(jù)分布是指數(shù)據(jù)集中所有可能值出現(xiàn)的頻率,并用概率來(lái)表示,它描述了數(shù)據(jù)取值的可能性,Seaborn 是一個(gè)基于 Matplotlib 的 Python 數(shù)據(jù)可視化庫(kù),用于創(chuàng)建統(tǒng)計(jì)圖表,本文就給大家詳細(xì)的介紹一下NumPy隨機(jī)數(shù)據(jù)分布與Seaborn可視化,需要的朋友可以參考下2024-05-05

