Python合并字典鍵值并去除重復(fù)元素的實例
假設(shè)在python中有一字典如下:
x={‘a(chǎn)':'1,2,3', ‘b':'2,3,4'}
需要合并為:
x={‘c':'1,2,3,4'}
需要做到三件事:
1. 將字符串轉(zhuǎn)化為數(shù)值列表
2. 合并兩個列表并添加新的鍵值
3. 去除重復(fù)元素
第1步通過常用的函數(shù)eval()就可以做到了,第2步需要添加一個鍵值并添加元素,第3步利用set集合的性質(zhì)可以達到去重的效果,不過最后需要再將set集合轉(zhuǎn)化為list列表。代碼如下:
x={'a':'1,2,3','b':'2,3,4'} x['c']=list(set(eval(x['a'])+eval(x['b']))) del x['a'] del x['b'] print x
輸出結(jié)果為:
{'c': [1, 2, 3, 4]}
但是在批量處理中,可能會其中一個鍵值的元素只有1個,導(dǎo)致編譯器會識別為int類型,導(dǎo)致出現(xiàn)錯誤。
x={'a':'1,2,3','b':'2'} x['c']=list(set(eval(x['a'])+eval(x['b']))) del x['a'] del x['b'] print x
運行結(jié)果為:
Traceback (most recent call last): File "test.py", line 2, in <module> x['c']=list(set(eval(x['a'])+eval(x['b']))) TypeError: can only concatenate tuple (not "int") to tuple
處理方法是,人為地將'b'中的元素復(fù)制一份,使編譯器不識別為int:
x={'a':'1,2,3','b':'2'} x['c']=list(set(eval(x['a'])+eval(x['b']+','+x['b']))) del x['a'] del x['b'] print x
這樣就能正常運行。這里利用了set會去去除重復(fù)元素的特點,添加了相同的元素。不過,若是'b'中的元素為空,這個方法也會失效。這里需要利用python列表中最后一個元素后面允許跟一個逗號的性質(zhì),按如下方法處理即可。
x={'a':'1,2,3','b':''} x['c']=list(set(eval(x['a']+','+x['b']))) del x['a'] del x['b'] print x
運行結(jié)果:
{'c': [1, 2, 3]}
最后一種方法也能夠處理前兩種情況。
以上這篇Python合并字典鍵值并去除重復(fù)元素的實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
解決Django的request.POST獲取不到內(nèi)容的問題
今天小編就為大家分享一篇解決Django的request.POST獲取不到內(nèi)容的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-05-05