迷人的学霸操作!教你Python中合并字典的多种解题方法

发表于:2020-5-08 09:52

字体: | 上一篇 | 下一篇 | 我要投稿

 作者:读芯术    来源:读芯术

#
Python
分享:
  Python 3.9现在处于初始开发阶段,但其中让人惊喜的新功能可不少。其中一个是颠覆性的,它能使处理Python字典时编写的代码更具可读性也更精简。
  第一个稳定版本应该在2020年10月问世。在与它正式见面前,有一些问题必须搞清楚。
  Python字典
  字典是Python中特有的数据结构。它包含多个元素,每个元素都是一个键值对。例如,初始化包含两个元素的字典d1。键“name”的值为“Tom”,而键“age”的值为20。
 d1 ={'name': 'Tom', 'age': 20}
  该字典存储了20岁的Tom的信息。
  假设出于某些原因我们收集了汤姆的更多信息,例如他的GPA和婚姻状况。现在可以创建另一个名为d2的字典。
 d2 ={'gpa': 4.0, 'is_single': True}
  现在想将这两个字典合并在一起,因为它们包含着同一个人(Tom)的不同信息。
  那么问题来了,如何在Python中合并两个字典?
  1. 笨方法
  可以使用语句dict_name[key] = value中的赋值运算符“=”在现有字典中插入新元素。
   d1 ={'name': 'Tom', 'age': 20}
  d1['sex'] = 'Male'# d1 == {'name': 'Tom', 'age': 20, 'sex': 'Male'}
  因此,在不使用任何特定的字典方法的情况下,想到的第一个方法是编写一个for循环,使用iterable .items()在每个键值对上进行迭代,然后将该对插入新的字典dnew中。
   d1 ={'name': 'Tom', 'age': 20}
  d2 = {'gpa': 4.0, 'is_single': True}
  dnew = dict()for key, value in d1.items():
  dnew[key] = value
  for key, value in d2.items():
  dnew[key] = value# dnew == {'name':'Tom', 'age': 20, 'gpa': 4.0, 'is_single': True}
  但是,合并字典应该是非常简单明了的,并且应该用一行代码就可以实现。
  2. 默认方法
  实际上,有一个内置方法可以将字典d1与另一个字典d2“更新”。
   dnew =d1.copy()
  dnew.update(d2)
  一个缺点是.update()方法就地修改字典。需要先复制d1来创建新字典dnew。这种“内置”方法无法方便地合并字典。
  可以合并成一行代码吗?可以!
  3. “整洁”的方法
  Python从版本3.5+起支持字典解压**。可以通过解压两个字典中的元素来创建新的“合并”字典。
 dnew ={**d1, **d2}
  这种解压方法成为Python3.5+合并字典的实际使用的方法。但是,这种语法在某些人看来可能不美观,而且对大多数人来说显然也不直观。当初次看到的时候,能猜到是什么意思吗?
  还有另一种简洁的方法可以用一行代码就将字典合并。它看起来也不直观。
 dnew =dict(d1, **d2)
  4. Python 3.9中干净的方法
  Python 3.9引入了一种新的干净的(!)方法,使用联合运算符“|”合并字典。非常简洁。
 dnew =d1 | d2# dnew == {'name': 'Tom', 'age': 20, 'gpa': 4.0, 'is_single': True}
  该联合运算符实际上在Python中并不新鲜。它可以用于“合并”两个集合。集合是无序且未索引的集合,也用花括号括起来。
   a = {1,2, 3}
  b = {3, 4, 5}
  print( a | b )
  # {1, 2, 3, 4, 5}
  拓展赋值
  对于两个列表或两个值a和b,a += b是a = a + b的缩写。这种拓展赋值行为也适用于字典联合运算符。这意味着d1 | = d2等于d1 = d1 | d2。
  注意事项
  集合是无序的,字典是按顺序插入的(Python 3.6),即字典会记住插入元素的顺序。这意味着字典并集是不可交换的。d1 | d2和d2 | d1将导致合并的字典元素顺序不同。
  不满足于仅仅得出答案,“学霸”追求的是最优解法。这道题目,你学会了嘛?

     本文内容不用于商业目的,如涉及知识产权问题,请权利人联系博为峰小编(021-64471599-8017),我们将立即处理
《2023软件测试行业现状调查报告》独家发布~

关注51Testing

联系我们

快捷面板 站点地图 联系我们 广告服务 关于我们 站长统计 发展历程

法律顾问:上海兰迪律师事务所 项棋律师
版权所有 上海博为峰软件技术股份有限公司 Copyright©51testing.com 2003-2024
投诉及意见反馈:webmaster@51testing.com; 业务联系:service@51testing.com 021-64471599-8017

沪ICP备05003035号

沪公网安备 31010102002173号