要从字典列表中删除重复项:
dict.values()
方法只获取唯一的字典。list()
类将结果转换为列表。list_of_dictionaries = [
{'id': 1, 'site': 'jiyik.com'},
{'id': 2, 'site': 'google.com'},
{'id': 1, 'site': 'jiyik.com'},
]
result = list(
{
dictionary['id']: dictionary
for dictionary in list_of_dictionaries
}.values()
)
# ️ [{'id': 1, 'site': 'jiyik.com'}, {'id': 2, 'site': 'google.com'}]
print(result)
我们使用字典理解来遍历字典列表。
字典理解与列表理解非常相似。
他们对字典中的每个键值对执行一些操作,或者选择满足条件的键值对的子集。
在每次迭代中,我们将当前 id 的值设置为键,将实际字典设置为值。
字典中的键是唯一的,因此任何重复的值都会被删除。
然后我们使用 dict.values()
方法只返回唯一的字典。
dict.values
方法返回字典值的新视图。
my_dict = {'id': 1, 'name': 'jiyik'}
print(my_dict.values()) # ️ dict_values([1, 'jiyik'])
最后一步是使用 list()
类将视图对象转换为包含唯一字典的列表。
列表类接受一个可迭代对象并返回一个列表对象。
或者,我们可以使用 for
循环。
要从字典列表中删除重复项:
for
循环遍历字典列表。list.append()
方法将非重复字典添加到新列表中。list_of_dictionaries = [
{'id': 1, 'site': 'jiyik.com'},
{'id': 2, 'site': 'google.com'},
{'id': 1, 'site': 'jiyik.com'},
]
new_list = []
for dictionary in list_of_dictionaries:
if dictionary not in new_list:
new_list.append(dictionary)
# ️ [{'id': 1, 'site': 'jiyik.com'}, {'id': 2, 'site': 'google.com'}]
print(new_list)
我们使用 for 循环遍历字典列表。
在每次迭代中,我们使用
not in
运算符来检查字典是否不存在于新列表中。
如果满足条件,我们使用 list.append()
方法将字典附加到列表中。
in 运算符测试成员资格。 例如,如果 x 是 l 的成员,则 x in l
的计算结果为 True,否则,它的计算结果为 False。
x not in l
返回 x in l 的否定。
list.append()
方法将一个项目添加到列表的末尾。
my_list = ['fql', 'jiyik']
my_list.append('com')
print(my_list) # ️ ['fql', 'jiyik', 'com']