标签:而且 pre 语句 回顾 赋值 识别 val 阶段 推荐文章
Python 3.9现在处于初始开发阶段,但其中让人惊喜的新功能可不少。其中一个是颠覆性的,它能使处理Python字典时编写的代码更具可读性也更精简。
第一个稳定版本应该在2020年10月问世。在与它正式见面前,有一些问题必须搞清楚。
字典是Python中特有的数据结构。它包含多个元素,每个元素都是一个键值对。例如,初始化包含两个元素的字典d1。键“name”的值为“Tom”,而键“age”的值为20。
d1 ={ name : Tom , age : 20}
该字典存储了20岁的Tom的信息。
假设出于某些原因我们收集了汤姆的更多信息,例如他的GPA和婚姻状况。现在可以创建另一个名为d2的字典。
d2 ={ gpa : 4.0, is_single : True}
现在想将这两个字典合并在一起,因为它们包含着同一个人(Tom)的不同信息。
那么问题来了,如何在Python中合并两个字典?
可以使用语句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}
但是,合并字典应该是非常简单明了的,并且应该用一行代码就可以实现。
图源:unsplash
实际上,有一个内置方法可以将字典d1与另一个字典d2“更新”。
dnew =d1.copy()
dnew.update(d2)
一个缺点是.update()方法就地修改字典。需要先复制d1来创建新字典dnew。这种“内置”方法无法方便地合并字典。
可以合并成一行代码吗?可以!
Python从版本3.5+起支持字典解压**。可以通过解压两个字典中的元素来创建新的“合并”字典。
dnew ={d1, d2}
这种解压方法成为Python3.5+合并字典的实际使用的方法。但是,这种语法在某些人看来可能不美观,而且对大多数人来说显然也不直观。当初次看到的时候,能猜到是什么意思吗?
还有另一种简洁的方法可以用一行代码就将字典合并。它看起来也不直观。
dnew =dict(d1, **d2)
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。
图源:unsplash
集合是无序的,字典是按顺序插入的(Python 3.6),即字典会记住插入元素的顺序。这意味着字典并集是不可交换的。d1 | d2和d2 | d1将导致合并的字典元素顺序不同。
不满足于仅仅得出答案,“学霸”追求的是最优解法。这道题目,你学会了嘛?
编译组:齐欣、杨月
相关链接:
https://towardsdatascience.com/merging-dictionaries-in-python-3-9-3b0409aa91a8
如转载,请后台留言,遵守转载规范
ACL2018论文集50篇解读
EMNLP2017论文集28篇论文解读
2018年AI三大顶会中国学术成果全链接
ACL2017论文集:34篇解读干货全在这里
10篇AAAI2017经典论文回顾
标签:而且 pre 语句 回顾 赋值 识别 val 阶段 推荐文章
原文地址:https://blog.51cto.com/15057819/2565646