python 字典操作提取key,value的方法
python 字典操作提取key,value dictionaryName[key] = value
1.為字典增加一項(xiàng)

2.訪問(wèn)字典中的值

3、刪除字典中的一項(xiàng)

4、遍歷字典

5、字典遍歷的key\value

6、字典的標(biāo)準(zhǔn)操作符

7、判斷一個(gè)鍵是否在字典中

8、python中其他的一些字典方法


9、將兩個(gè)字典合并
a={'a':1,'b':2,'c':3}
b= {'aa':11,'bb':22,'cc':33}
#方法一
print(dict(a,**b))
#方法二 這其實(shí)就是在內(nèi)存中創(chuàng)建兩個(gè)列表,再創(chuàng)建第三個(gè)列表,拷貝完成后,創(chuàng)建新的dict,刪除掉前三個(gè)列表。這個(gè)方法耗費(fèi)性能,而且對(duì)于python3,這個(gè)無(wú)法成功執(zhí)行,因?yàn)閕tems()返回是個(gè)對(duì)象。
print(dict(list(a.items())+list(b.items())))
#方法三
c={}
c.update(a)
c.update(b)
print(c)
#方法四 python 3.5支持,可以存在重復(fù)鍵值,比如說(shuō):a={'a':1,'b':2,'c':3,'aa':12}會(huì)報(bào)錯(cuò)TypeError: print() got multiple values for keyword argument 'aa'
print(**a,**b)
他們的輸出結(jié)果都是:
{'bb': 22, 'cc': 33, 'aa': 11, 'a': 1, 'b': 2, 'c': 3}
注意如果存在相同鍵值,比如說(shuō):
a={'a':1,'b':2,'c':3,'aa':12} b= {'aa':11,'bb':22,'cc':33}
那么方法一\二\三得到結(jié)果為
{'cc': 33, 'a': 1, 'bb': 22, 'c': 3, 'b': 2, 'aa': 11}
而方法四則會(huì)報(bào)錯(cuò):
TypeError: print() got multiple values for keyword argument ‘a(chǎn)a'
10、key和value互換
方法一:
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
dict_ori = {'A':1, 'B':2, 'C':3}
dict_new = {value:key for key,value in dict_ori.items()}
print(dict_new)
{1: ‘A', 2: ‘B', 3: ‘C'}
方法二:
使用zip方法
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
dict_ori = {'A':1, 'B':2, 'C':3}
dict_new2= dict(zip(dict_ori.values(), dict_ori.keys()))
print(dict_new2)
{1: ‘A', 2: ‘B', 3: ‘C'}
11、字典多鍵值及重復(fù)鍵值的使用方法(詳解)
方案一
#encoding=utf-8
print ('中國(guó)')
#字典的一鍵多值
print('方案一 list作為dict的值 值允許重復(fù)' )
d1={}
key=1
value=2
d1.setdefault(key,[]).append(value)
value=2
d1.setdefault(key,[]).append(value)
print (d1)
#獲取值
print ('方案一 獲取值')
print (list(d1[key]) )
print( '方案一 刪除值,會(huì)留下一個(gè)空列表' )
d1[key].remove(value)
d1[key].remove(value)
print (d1 )
print ('方案一 檢查是否還有一個(gè)值' )
print (d1.get(key,[]) )
方案一輸出結(jié)果
中國(guó)
方案一 list作為dict的值 值允許重復(fù)
{1: [2, 2]}
方案一 獲取值
[2, 2]
方案一 刪除值,會(huì)留下一個(gè)空列表
{1: []}
方案一 檢查是否還有一個(gè)值
[]
方案二
print ('方案二 使用子字典作為dict的值 值不允許重復(fù)')
d1={}
key=1
keyin=2
value=11
d1.setdefault(key,{})[keyin]=value
keyin=2
value=22
d1.setdefault(key,{})[keyin]=value
keyin=3
value=33
d1.setdefault(key,{})[keyin]=value
print (d1 )
print ('方案二 獲取值' )
print (list(d1[key]) )
print ('方案二 刪除值,會(huì)留下一個(gè)空列表' )
del d1[key][keyin]
keyin=2
del d1[key][keyin]
print (d1)
print ('方案二 檢查是否還有一個(gè)值')
print (d1.get(key,()) )
方案二輸出結(jié)果
方案二 使用子字典作為dict的值 值不允許重復(fù)
{1: {2: 22, 3: 33}}
方案二 獲取值
[```2, 3]
方案二 刪除值,會(huì)留下一個(gè)空列表
{1: {}}
方案二 檢查是否還有一個(gè)值
{}
方案三
print ('方案三 使用set作為dict的值 值不允許重復(fù)')
d1={}
key=1
value=2
d1.setdefault(key,set()).add(value)
value=2
d1.setdefault(key,set()).add(value)
value=3
d1.setdefault(key,set()).add(value)
print ('方案三 獲取值' )
print (list(d1[key]) )
print ('方案三 刪除值,會(huì)留下一個(gè)空列表')
d1[key].remove(value)
value=2
d1[key].remove(value)
print (d1 )
print ('方案三 檢查是否還有一個(gè)值' )
print (d1.get(key,()) )
輸出結(jié)果:
方案三 使用set作為dict的值 值不允許重復(fù)
{1: {2, 3}}
方案三 獲取值
[2, 3]
方案三 刪除值,會(huì)留下一個(gè)空列表
{1: set()}
方案三 檢查是否還有一個(gè)值
set()
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
命令行傳遞參數(shù)argparse.ArgumentParser的使用解析
這篇文章主要介紹了命令行傳遞參數(shù)argparse.ArgumentParser的使用解析,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-02-02
一文教會(huì)你用Python3獲取網(wǎng)頁(yè)源代碼
學(xué)了python后,之前一些我們常用的方法,也可以換一種思路用python中的知識(shí)來(lái)解決,下面這篇文章主要給大家介紹了關(guān)于如何使用Python3獲取網(wǎng)頁(yè)源代碼的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06
基于python3抓取pinpoint應(yīng)用信息入庫(kù)
這篇文章主要介紹了基于python3抓取pinpoint應(yīng)用信息入庫(kù),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-01-01
python 實(shí)現(xiàn)按對(duì)象傳值
今天小編就為大家分享一篇python 實(shí)現(xiàn)按對(duì)象傳值,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-12-12
python實(shí)現(xiàn)rest請(qǐng)求api示例
這篇文章主要介紹了python實(shí)現(xiàn)rest請(qǐng)求api示例,需要的朋友可以參考下2014-04-04
django1.8使用表單上傳文件的實(shí)現(xiàn)方法
Django是一個(gè)開(kāi)放源代碼的Web應(yīng)用框架,由Python寫(xiě)成。這篇文章主要介紹了django1.8使用表單上傳文件的相關(guān)資料,非常不錯(cuò)具有參考借鑒價(jià)值,感興趣的朋友一起看看吧2016-11-11
Python使用Keras庫(kù)中的LSTM模型生成新文本內(nèi)容教程
Python語(yǔ)言使用金庸小說(shuō)文本庫(kù),對(duì)文本進(jìn)行預(yù)處理,然后使用Keras庫(kù)中的LSTM模型創(chuàng)建和訓(xùn)練了模型,根據(jù)這個(gè)模型,我們可以生成新的文本,并探索小說(shuō)的不同應(yīng)用2024-01-01

