兩個字典以下:python
合併後的結果以下(即,key相同時後面字典值覆蓋前面字典):ui
{'sex': 'male', 'name': 'revotu', 'age': 24}
首先,說明字典並不支持+加法運算spa
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: unsupported operand type(s) for +: 'dict' and 'dict'
現總結以下幾種方法以及簡要分析比較。code
首先建立一個空字典,並使用update方法向字典中添加元素。注意,先添加的是d1,以保證後面添加的d2重複鍵會覆蓋d1。
此方法知足了咱們的要求,並且清晰明確,但是三行代碼總感受不夠Pythonic。對象
對比方法一,這種複製d1的方法,更明顯的表現出d1做爲默認值。字符串
與方法二很類似,可是沒有方法二直接明瞭。string
只有一行代碼,看上去很酷,可是有一個問題,這種hack技巧只有在字典的鍵是字符串時纔有效。it
看上去很cool,可是不通用,字典的鍵必須是字符串才能夠用這種關鍵字參數方法。io
字典推導式方法知足要求,只是嵌套的字典推導式,不那麼清晰,不易於理解。ast
>>> d = dict(list(d1.items()) + list(d2.items()))
並且,d2的元素在列表後面,因此在鍵重複時能夠覆蓋d1。若是在Python2中,items()方法自己返回的就是列表,無需用list()轉成列表。
元素拼接在構造字典能夠知足要求,只是看上去代碼有些重複。
>>> d = dict(d1.items() | d2.items())
這種方法挺有意思,但是並不許確,由於集合是無序的,鍵重複時不能保證誰覆蓋誰,並且字典中的值一般也是不可哈希的,固然也就不能返回一個相似集合的對象。
>>> d = dict(chain(d1.items(), d2.items()))
這種方案很不錯,可能比另外建立兩個沒必要要的列表更高效。
這種方法也很pythonic,並且也是通用方法。
>>> d = {**d1, **d2}
這行代碼很pythonic,若是是你的python版本是3.5+,用這種方法是很不錯的選擇。
上面說了十種能夠合併兩個字典成一個新字典的方式,具體用哪一個取決於你。
若是使用的是Python3.5+的版本,那麼字典拆分這種新語法應該很適合你: