淺析python 字典嵌套
為什么需要嵌套?
有時(shí)候,需要將一系列字典存儲(chǔ)在列表中,或?qū)⒘斜碜鳛橹荡鎯?chǔ)在字典中,這稱為嵌套 。你可以在列表中嵌套字典、在字典中嵌套列表甚至在字典中嵌套字典。
字典列表
例如:字典alien_0包含一個(gè)外星人的信息,但無法存儲(chǔ)第二個(gè)外星人的信息。怎么辦呢?
我們可以創(chuàng)建三個(gè)外星人字典,那么問題來了,我們需要的是大量的外星人,有沒有更簡(jiǎn)單的方式呢?
alien_0 = {'color':'blue','points':'5'} alien_1 = {'color':'blue','points':'5'} alien_2 = {'color':'blue','points':'5'}
aliens = [] for number in range(5): new_alient = {'color':'blue','points':'5','speed':'slow'} aliens.append(new_alient) for i in aliens: print(i) print(str(len(aliens)))
輸出
{'color': 'blue', 'points': '5', 'speed': 'slow'}
{'color': 'blue', 'points': '5', 'speed': 'slow'}
{'color': 'blue', 'points': '5', 'speed': 'slow'}
{'color': 'blue', 'points': '5', 'speed': 'slow'}
{'color': 'blue', 'points': '5', 'speed': 'slow'}
5
這些外星人都有相同的特征。在python看來,每個(gè)外星人都是獨(dú)立的,但是這樣并不符合業(yè)務(wù)需求。
例如:將前三個(gè)外星人修改成黃色、速度中等且值為10個(gè)點(diǎn)
aliens = [] for number in range(5): new_alient = {'color':'blue','points':'5','speed':'slow'} aliens.append(new_alient) for alien in aliens[:3]: if alien['color'] == 'blue': alien['color'] = 'yellow' alien['speen'] = 'medium' alien['points'] = 10 for alien in aliens: print(alien)
輸出
{'color': 'yellow', 'points': 10, 'speed': 'slow', 'speen': 'medium'}
{'color': 'yellow', 'points': 10, 'speed': 'slow', 'speen': 'medium'}
{'color': 'yellow', 'points': 10, 'speed': 'slow', 'speen': 'medium'}
{'color': 'blue', 'points': '5', 'speed': 'slow'}
{'color': 'blue', 'points': '5', 'speed': 'slow'}
這里還可以使用if-elif-else語句,更加詳細(xì)的表述每個(gè)外星人的屬性。
在字典中存儲(chǔ)列表
例如:買煎餅果子的時(shí)候,使用列表的話可以描述煎餅果子可以加什么配料。如果使用字典,不僅能描述配料,還能描述煎餅果子的產(chǎn)地等信息
jbgz = {'origin':'天津','toppings':['雞蛋','香腸']} print('煎餅果子產(chǎn)地是:' + jbgz['origin'] + '。你可以選擇添加:') for topping in jbgz['toppings']: print(topping)
輸出
煎餅果子產(chǎn)地是:天津。你可以選擇添加:
雞蛋
香腸
例如:調(diào)查程序員們喜歡都喜歡什么編程語言
languages = { 'jens':['python','java'], 'sarah':['c','ruby'], 'hack':['go'] } for name,language in languages.items(): print(name.title() + "'s favorite languages are:") for i in language: print('\t' + i.title())
輸出
Jens's favorite languages are:
Python
Java
Sarah's favorite languages are:
C
Ruby
Hack's favorite languages are:
Go
在字典中存儲(chǔ)字典
例如:網(wǎng)站內(nèi)存儲(chǔ)每個(gè)用戶的姓、名、住址,訪問這些信息
users = { '岳云鵬':{ '姓':'岳', '名':'龍剛', '住址':'北京' }, '孟鶴堂':{ '姓':'孟', '名':'祥輝', '住址':'北京' } } for username,user_info in users.items(): print('\n藝名:'+ username) full_name = user_info['姓'] + '' + user_info['名'] location = user_info['住址'] print('\t姓名:' + full_name) print('\t住址:' + location)
輸出
藝名:岳云鵬
姓名:岳龍剛
住址:北京藝名:孟鶴堂
姓名:孟祥輝
住址:北京
以上就是淺析python 字典嵌套的詳細(xì)內(nèi)容,更多關(guān)于python 字典嵌套的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
Python實(shí)現(xiàn)繪制自定義形狀的詞云示例
這篇文章主要介紹了Python實(shí)現(xiàn)繪制自定義形狀的詞云示例,通過將一段文本中出現(xiàn)頻率高的單詞按其出現(xiàn)頻率大小以及顏色深淺排列成一個(gè)詞云圖形,從而更好地展示文本中的信息,需要的朋友可以參考下2022-10-10Python增強(qiáng)賦值和共享引用注意事項(xiàng)小結(jié)
這篇文章主要給大家介紹了關(guān)于Python增強(qiáng)賦值和共享引用注意事項(xiàng)的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用Python具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-05-05Python2.x和3.x下maketrans與translate函數(shù)使用上的不同
這篇文章主要介紹了Python2.x和3.x下maketrans與translate函數(shù)使用上的不同,這兩個(gè)函數(shù)建立映射來替換內(nèi)容是Python學(xué)習(xí)當(dāng)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-04-04Python中l(wèi)ogging日志記錄到文件及自動(dòng)分割的操作代碼
這篇文章主要介紹了Python中l(wèi)ogging日志記錄到文件及自動(dòng)分割,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-08-08python通過nmap掃描在線設(shè)備并嘗試AAA登錄(實(shí)例代碼)
這篇文章主要介紹了python通過nmap掃描在線設(shè)備并嘗試AAA登錄,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-12-12Python多線程中阻塞(join)與鎖(Lock)使用誤區(qū)解析
這篇文章主要為大家詳細(xì)介紹了Python多線程中阻塞join與鎖Lock的使用誤區(qū),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-04-04