通過(guò)序列生成字典
我們將下面的序列轉(zhuǎn)換為dict類(lèi)型。
lst=[('a',1),('b',2),('c',3)]
普通的寫(xiě)法
fork,vinlst:
dic[k]=v
更pythonic的寫(xiě)法
利用字典推導(dǎo)式快速生成字典。
{k:vfork,vinlst}
key的默認(rèn)值
當(dāng)指定key不存在時(shí),將value設(shè)置為 0。
普通的寫(xiě)法
ifkeynotindct:
dct[key]=0
pythonic的寫(xiě)法
dct[key]=dct.get(key,0)
交換key與value
普通的寫(xiě)法
dic={'Python':1,'Java':2}
new_dic={}
fork,vindic.items():
new_dic[v]=k
更pythonic的寫(xiě)法
dic={'Python':1,'Java':2}
new_dic={v:kfork,vindic.items()}
序列修改和初始化
示例數(shù)據(jù)
lst=[('a',1),('b',2),('c',3)]
dic={'a':[0]}
如果我們需要根據(jù)lst來(lái)更新dic中的數(shù)據(jù),當(dāng)key存在,則將value添加到原序列末尾,否則初始化value并用序列保存。
普通的寫(xiě)法
forkey,valueinlst:
ifkeyindic:
dic[key].append(value)
else:
dic[key]=[value]
更pythonic的寫(xiě)法
for(key,value)inlst:
group=dic.setdefault(key,[])
group.append(value)
# dic:{'a':[0, 1], 'b':[2], 'c':[3]}
setdefault(key, default)會(huì)先判斷key是否存在,存在則返回dct[key], 不存在則把dct[key]設(shè)為 [] 并返回。
key,items的集合運(yùn)算
如果我們現(xiàn)在需要獲取兩個(gè)字典的key相交的部分的映射信息。
普通的寫(xiě)法
dic1={'Python':1,'Java':2,'C':3}
dic2={'Python':3,'Java':2,'C++':1}
new_dic={}
fork,vindic1.items():
ifkindic2.keys():
new_dic[k]=v
print(new_dic)
#{'Python':1,'Java':2}
更pythonic的寫(xiě)法
dic1={'Python':1,'Java':2,'C':3}
dic2={'Python':3,'Java':2,'C++':1}
print({k:dic1[k]forkindic1.keys()&dic2.keys()})
#{'Python':1,'Java':2}
這里的dic1.keys() & dic2.keys()用到的就是keys()進(jìn)行集合運(yùn)算,items()同樣可以進(jìn)行集合運(yùn)算。
如果現(xiàn)在我們要獲取兩個(gè)字典中key,value完全相同的部分。
dic1={'Python':1,'Java':2,'C':3}
dic2={'Python':3,'Java':2,'C++':1}
print(dic1.items()&dic2.items())
#{('Java',2)}
靈活運(yùn)用 keys,items() 集合運(yùn)算的特性,可以快速提取我們想要的內(nèi)容。
按key或value對(duì)字典排序
使用sorted()函數(shù)快速實(shí)現(xiàn)對(duì)key或value的排序。
dic={'a':2,'b':1,'c':3,'d':0}
lst1=sorted(dic.items(),key=lambdax:x[0],reverse=False)
#[('a',2),('b',1),('c',3),('d',0)]
lst2=sorted(dic.items(),key=lambdax:x[1],reverse=False)
#[('d',0),('b',1),('a',2),('c',3)]
print('按照鍵降序:',{key:valueforkey,valueinlst1})
print('按照值降序:',{key:valueforkey,valueinlst2})
#按照鍵降序:{'a': 2, 'b': 1, 'c': 3, 'd':0}
#按照值降序:{'d':0, 'b': 1, 'a': 2, 'c': 3}
多個(gè)字典排序
如果一個(gè)序列中包含多個(gè)字典,現(xiàn)在要根據(jù)條件對(duì)這些字典繼續(xù)排序。同樣可以使用sorted()函數(shù)來(lái)實(shí)現(xiàn)。
dict_list=[
{'letter':'B','number':'2'},
{'letter':'A','number':'3'},
{'letter':'B','number':'1'}
]
#按letter排序
print(sorted(dict_list,
key=lambdadic:dic['letter']))
#按letter,number排序
print(sorted(dict_list,
key=lambdadic:(dic['letter'],dic['number'])))
#[{'letter':'A','number':'3'},{'letter':'B','number':'2'},{'letter':'B','number':'1'}]
#[{'letter':'A','number':'3'},{'letter':'B','number':'1'},{'letter':'B','number':'2'}]
當(dāng)然,如果你知道itemgetter()的話(huà),上面的代碼就可以改變一下,執(zhí)行速度會(huì)更快。
fromoperatorimportitemgetter
print(sorted(dict_list,
key=itemgetter('letter')))
print(sorted(dict_list,
key=itemgetter('letter','number')))
itemgetter()獲取的不是值,而是定義了一個(gè)函數(shù),通過(guò)該函數(shù)作用到目標(biāo)對(duì)象上。
審核編輯:湯梓紅
-
函數(shù)
+關(guān)注
關(guān)注
3文章
4413瀏覽量
67199 -
python
+關(guān)注
關(guān)注
57文章
4866瀏覽量
89801
發(fā)布評(píng)論請(qǐng)先 登錄
ATA-D60090功率放大器在時(shí)間調(diào)制序列生成中的應(yīng)用
思必馳一鳴智能客服大模型通過(guò)生成式人工智能服務(wù)備案
中車(chē)斫輪大模型通過(guò)國(guó)家生成式人工智能服務(wù)備案
canopen如何通過(guò)對(duì)象字典控制外設(shè)?
小紅書(shū):通過(guò)商品標(biāo)簽API自動(dòng)生成內(nèi)容標(biāo)簽,優(yōu)化社區(qū)推薦算法
termux調(diào)試python猜數(shù)字游戲
termux如何搭建python游戲
NVIDIA recsys-examples在生成式推薦系統(tǒng)中的高效實(shí)踐
基礎(chǔ)篇3:掌握Python中的條件語(yǔ)句與循環(huán)
python入門(mén)圣經(jīng)-高清電子書(shū)(建議下載)
聲智APP通過(guò)北京市生成式人工智能服務(wù)登記
?Diffusion生成式動(dòng)作引擎技術(shù)解析
dlp3010如何通過(guò)RGB888通道,讓dlp3010投影序列圖?
Python中的迭代器與生成器
開(kāi)源隨機(jī)數(shù)生成器庫(kù)OpenRNG助力實(shí)現(xiàn)移植到Arm平臺(tái)時(shí)的最佳性能
python通過(guò)序列生成字典
評(píng)論