python 合并dict
問題描述
現(xiàn)在有兩個(gè)dict,這個(gè)dict有兩層(如果可以自定義層數(shù)或者不限更好),想合并起來(lái)
case1:輸入:a: {1:{'171': True}} b:{1:{'172': False}}輸出:{1:{'171': True, '172': False}}
case2:輸入:a: {1:{'171': True}} b:{1:{'171': False}}輸出:{1:{'171': False}}
我使用python的dict.update方法都是只能一層,不知道有沒有好的實(shí)現(xiàn)方法?
問題解答
回答1:隨手寫了一個(gè) 應(yīng)對(duì)多層 dictionary 的 merge
from itertools import chainfrom functools import reducedef deep_merge_func(acc, item): if not acc:acc = {} k, v = item if isinstance(v, dict):original_v = acc.get(k)if original_v and isinstance(original_v, dict): return {**acc, k: deep_merge(original_v, v)} return {**acc, k: v}def deep_merge(origin, target): return reduce(deep_merge_func, chain(origin.items(), target.items()), None)a = {1: {'171': True}}b = {1: {'171': False}}print(deep_merge(a, b))c = {1: {'171': True}}d = {1: {'172': False}}print(deep_merge(c ,d))
只測(cè)試了 python3.6.1 你只需要調(diào)用 deep_merge 就行了
寫得比較 functional 不要怪我
回答2:對(duì)于case2就比較簡(jiǎn)單:
>>> a={1:{'171': True}}>>> b={1:{'171':False}}>>> a.update(b)>>> a{1: {’171’: False}}
對(duì)于case1可以這樣操作:
>>> c={}>>> for k,v in a.items():... if k in b:... v.update(b[k])... c[k] = v... >>> c{1: {’172’: False, ’171’: True}}
你將上述操作封裝為函數(shù)即可。
相關(guān)文章:
1. javascript - 按鈕鏈接到另一個(gè)網(wǎng)址 怎么通過百度統(tǒng)計(jì)計(jì)算按鈕的點(diǎn)擊數(shù)量2. sql語(yǔ)句 - 如何在mysql中批量添加用戶?3. mysql 可以從 TCP 連接但是不能從 socket 鏈接4. mysql - PHP定時(shí)通知、按時(shí)發(fā)布怎么做?5. 怎么php怎么通過數(shù)組顯示sql查詢結(jié)果呢,查詢結(jié)果有多條,如圖。6. mysql - JAVA怎么實(shí)現(xiàn)一個(gè)DAO同時(shí)實(shí)現(xiàn)查詢兩個(gè)實(shí)體類的結(jié)果集7. 事務(wù) - mysql共享鎖lock in share mode的實(shí)際使用場(chǎng)景8. mysql建表索引問題求助9. mysql - 數(shù)據(jù)庫(kù)建字段,默認(rèn)值空和empty string有什么區(qū)別 11010. mysql 非主鍵做范圍查找實(shí)現(xiàn)原理的一點(diǎn)困惑
