使用字典列表时,可能需要根据相同的键删除重复项-值对。本文将提供有关如何使用 Python 的内置函数和保留字典顺序的更有效方法来实现此目的的详细指导。
一种方法是将每个字典转换为其项目的元组。由于元组是可散列的,因此它们可以用作集合中的键来识别重复的字典。以下 Python 代码演示了此方法:
new_list = [dict(t) for t in {tuple(d.items()) for d in old_list}]
此代码迭代原始字典列表 (old_list) 并创建一组表示每个字典中的项目的元组。该集合会自动删除重复项。然后使用字典理解将结果集转换回字典列表。
但是,如果字典的顺序很重要,则上述方法将不会保存它。为了实现这一点,建议使用以下替代方法:
seen = set() new_list = [] for d in old_list: t = tuple(sorted(d.items())) if t not in seen: seen.add(t) new_list.append(d)
此代码创建一组表示每个字典中有序项目的元组。 Sorted() 函数确保项目的顺序一致。然后,该集合用于排除重复的元组,并且结果列表保留原始字典顺序。
如果字典包含嵌套字典,则提供的代码需要稍微修改以展平嵌套结构。下面的代码片段说明了这一点:
def flatten_dict(d): new_d = {} for k, v in d.items(): if isinstance(v, dict): v = flatten_dict(v) for k2, v2 in v.items(): new_d[f'{k}.{k2}'] = v2 else: new_d[k] = v return new_d new_list = [dict(t) for t in {tuple(flatten_dict(d).items()) for d in old_list}]
在本文中,我们探索了两种在 Python 中从列表中删除重复字典的方法:使用集合进行重复数据删除和保留原始字典使用自定义逻辑进行排序。方法的选择取决于任务的具体要求。
以上是如何在保留顺序的同时从 Python 列表中删除重复的字典?的详细内容。更多信息请关注PHP中文网其他相关文章!