3 回答

TA貢獻(xiàn)1864條經(jīng)驗(yàn) 獲得超2個(gè)贊
在您的情況下,您可以執(zhí)行以下操作:
z = dict(list(x.items()) + list(y.items()))
可以根據(jù)需要將最終的dict放入中z,并b用第二個(gè)(y)dict的值正確覆蓋key的值:
>>> x = {'a':1, 'b': 2}
>>> y = {'b':10, 'c': 11}
>>> z = dict(list(x.items()) + list(y.items()))
>>> z
{'a': 1, 'c': 11, 'b': 10}
如果使用Python 2,甚至可以刪除list()調(diào)用。要?jiǎng)?chuàng)建z:
>>> z = dict(x.items() + y.items())
>>> z
{'a': 1, 'c': 11, 'b': 10}
如果您使用Python版本3.9.0a4或更高版本,則可以直接使用:
x = {'a':1, 'b': 2}
y = {'b':10, 'c': 11}
z = x | y
print(z)
{'a': 1, 'c': 11, 'b': 10}

TA貢獻(xiàn)1876條經(jīng)驗(yàn) 獲得超7個(gè)贊
這可能不是一個(gè)流行的答案,但是您幾乎可以肯定不想這樣做。如果要合并的副本,請(qǐng)使用copy(或deepcopy,具體取決于您的需求),然后進(jìn)行更新。與使用.items()+ .items()進(jìn)行單行創(chuàng)建相比,兩行代碼更具可讀性-更具Python風(fēng)格。顯式勝于隱式。
此外,當(dāng)您使用.items()(Python 3.0之前的版本)時(shí),您正在創(chuàng)建一個(gè)新列表,其中包含字典中的項(xiàng)目。如果您的詞典很大,那將是很多開銷(創(chuàng)建合并字典后將立即丟棄兩個(gè)大列表)。update()可以更高效地工作,因?yàn)樗梢灾痦?xiàng)執(zhí)行第二個(gè)字典。
在時(shí)間方面:
>>> timeit.Timer("dict(x, **y)", "x = dict(zip(range(1000), range(1000)))\ny=dict(zip(range(1000,2000), range(1000,2000)))").timeit(100000)
15.52571702003479
>>> timeit.Timer("temp = x.copy()\ntemp.update(y)", "x = dict(zip(range(1000), range(1000)))\ny=dict(zip(range(1000,2000), range(1000,2000)))").timeit(100000)
15.694622993469238
>>> timeit.Timer("dict(x.items() + y.items())", "x = dict(zip(range(1000), range(1000)))\ny=dict(zip(range(1000,2000), range(1000,2000)))").timeit(100000)
41.484580039978027
IMO出于可讀性考慮,前兩者之間的微小速度下降是值得的。此外,僅在Python 2.3中添加了用于字典創(chuàng)建的關(guān)鍵字參數(shù),而copy()和update()將在較早的版本中運(yùn)行。
添加回答
舉報(bào)