Python 中要在两个词典中查找公共键:
- 使用
dict.keys()
方法获取每个字典的键的视图对象。 - 使用
&
符号获取常用键。 - 使用
list()
类将结果转换为列表对象。
dict1 = {'name': 'jiyik', 'topic': 'Python', 'salary': 100}
dict2 = {'name': 'alice', 'salary': 100, 'experience': 5}
common_keys = list(dict1.keys() & dict2.keys())
print(common_keys) # 👉️ ['salary', 'name']
# ----------------------------------------------
common_k_v = {key: value for key, value in dict1.items()
if key in dict2}
# 👇️ {'name': 'jiyik', 'salary': 100}
print(common_k_v)
dict.keys
方法返回字典键的新视图。
dict1 = {'name': 'jiyik', 'topic': 'Python', 'salary': 100}
# 👇️ dict_keys(['name', 'topic', 'salary'])
print(dict1.keys())
视图对象是类似集合的对象,可以直接用于返回两个对象共有的元素。
dict1 = {'name': 'jiyik', 'topic': 'Python', 'salary': 100}
dict2 = {'name': 'alice', 'salary': 100, 'experience': 5}
common_keys = list(dict1.keys() & dict2.keys())
print(common_keys) # 👉️ ['salary', 'name']
符号
&
返回一个新集合,其中包含两个集合对象共有的元素(交集)。
最后一步是使用 list()
类将集合对象转换为列表。
或者,我们可以使用列表推导。
使用列表理解在两个词典中查找公共键
要在两个词典中查找公共键:
- 使用列表推导式遍历第一个字典。
- 检查每个键是否存在于第二个字典中并返回结果。
- 新列表将只包含字典中的常用键。
dict1 = {'name': 'jiyik', 'topic': 'Python', 'salary': 100}
dict2 = {'name': 'alice', 'salary': 100, 'experience': 5}
common_keys = [key for key in dict1
if key in dict2]
print(common_keys) # 👉️ ['name', 'salary']
我们使用列表推导来迭代第一个字典。
列表推导用于对每个元素执行某些操作或选择满足条件的元素子集。
在每次迭代中,我们使用 in
运算符来检查键是否存在于第二个字典中。
与字典一起使用时,
in
运算符会检查字典对象中是否存在指定键。
如果我们需要获取包含公共键和值的字典,请使用字典推导。
dict1 = {'name': 'jiyik', 'topic': 'Python', 'salary': 100}
dict2 = {'name': 'alice', 'salary': 100, 'experience': 5}
common_k_v = {key: value for key, value in dict1.items()
if key in dict2}
# 👇️ {'name': 'jiyik', 'salary': 99}
print(common_k_v)
字典推导与列表推导非常相似。
他们对字典中的每个键值对执行一些操作,或者选择满足条件的键值对的子集。
在每次迭代中,我们检查当前键是否存在于另一个字典中并返回键值对。
或者,我们可以使用简单的 for 循环。
使用 for 循环查找两个字典中的公共键
要在两个词典中查找公共键:
- 声明一个存储空列表的新变量。
- 使用 for 循环遍历第一个字典。
- 检查每个键是否包含在第二个字典中。
- 将匹配的键附加到列表中。
dict1 = {'name': 'jiyik', 'topic': 'Python', 'salary': 100}
dict2 = {'name': 'alice', 'salary': 100, 'experience': 5}
common_keys = []
for key in dict1:
if key in dict2:
common_keys.append(key)
print(common_keys) # 👉️ ['name', 'salary']
我们使用 for
循环遍历第一个字典。
在每次迭代中,我们检查当前键是否存在于第二个字典中。
如果满足条件,我们使用
list.append()
方法将键追加到列表中。list.append()
方法将一个项目添加到列表的末尾。
my_list = ['fql', 'jiyik']
my_list.append('com')
print(my_list) # 👉️ ['fql', 'jiyik', 'com']
选择哪种方法是个人喜好的问题。 我会使用列表推导,因为我发现它们非常直接且易于阅读。