Python中字典列表中删除重复项

要从字典列表中删除重复项:

  • 使用字典推导来遍历列表。
  • 使用每个 id 属性的值作为键,使用字典作为值。
  • 使用 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 循环从字典列表中删除重复项

要从字典列表中删除重复项:

  • 声明一个存储空列表的新变量。
  • 使用 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']

到此这篇关于Python中字典列表中删除重复项的文章就介绍到这了,更多相关Python字典删除重复项内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

(0)

相关推荐

  • python中的字典及嵌套遍历

    目录 python字典及嵌套遍历 访问字典里的值 修改字典 删除字典元素 嵌套字典遍历与内置函数 字典的常用方法(定义.新增.删除.更新.遍历.嵌套等) 什么是字典? 为什么需要字典? 字典 总结 python字典及嵌套遍历 字典是另一种可变容器模型,且可存储任意类型对象. 字典的每个键值 key:value 对用冒号 : 分割,每个键值对之间用逗号 , 分割,整个字典包括在花括号 {} 中 dict1={'apple':23,'banana':34,'cherry':6} dict2={'ja

  • 关于python实现json/字典数据中所有key路径拼接组合问题

    案例需求: 在已知的json数据或者字典数据中,获取所有key值的路径拼接值,并能够根据拼接路径获取对应的值. 示例代码: import jmespath data = { "id": 1, "name": '张三', "age": 25, "grade": { "Chinese": 99, "Math": 100 }, "records": [ { "Ch

  • Python3实现从排序数组中删除重复项算法分析

    本文实例讲述了Python3实现从排序数组中删除重复项算法.分享给大家供大家参考,具体如下: 题目:给定一个排序数组,你需要在原地删除重复出现的元素,使得每个元素只出现一次,返回移除后数组的新长度. 不要使用额外的数组空间,你必须在原地修改输入数组并在使用 O(1) 额外空间的条件下完成. 方案一:利用set()快速剔除重复元素. 效率最高 # -*- coding:utf-8 -*- #! python3 def removeDuclicates(nums): nums[:] = sorted

  • Python实现去除列表中重复元素的方法小结【4种方法】

    本文实例讲述了Python实现去除列表中重复元素的方法.分享给大家供大家参考,具体如下: 这里一共使用了四种方法来去除列表中的重复元素,下面是具体实现: #!usr/bin/env python #encoding:utf-8 ''' __Author__:沂水寒城 功能:去除列表中的重复元素 ''' def func1(one_list): ''''' 使用集合,个人最常用 ''' return list(set(one_list)) def func2(one_list): ''''' 使用

  • Python实现去除列表中重复元素的方法总结【7种方法】

    这里首先给出来我很早之前写的一篇博客,Python实现去除列表中重复元素的方法小结[4种方法],感兴趣的话可以去看看,今天是在实践过程中又积累了一些方法,这里一并总结放在这里. 由于内容很简单,就不再过多说明了,这里直接上代码,具体如下: # !/usr/bin/env python # -*- coding:utf-8 -*- ''' __Author__:沂水寒城 功能: python列表去除方法总结(7种方法) ''' import sys reload(sys) import copy

  • Python编程对列表中字典元素进行排序的方法详解

    本文实例讲述了Python编程对列表中字典元素进行排序的方法.分享给大家供大家参考,具体如下: 内容目录: 1. 问题起源 2. 对列表中的字典元素排序 3. 对json进行比较(忽略列表中字典的顺序) 一.问题起源 json对象a,b a = '{"ROAD": [{"id": 123}, {"name": "no1"}]}' b = '{"ROAD": [{"name": "

  • python中字典增加和删除使用方法

    增加操作: 变量名[key] = value   # 通过key添加value值,如果key存在则覆盖 user_info = {"name":"冯提莫","like":"喵喵喵"} user_info["height"] = 1.51 # 添加一个元素 print(user_info) #{'name': '冯提莫', 'like': '喵喵喵', 'height': 1.51 user_info[&qu

  • Python实现连接两个无规则列表后删除重复元素并升序排序的方法

    本文实例讲述了Python实现连接两个无规则列表后删除重复元素并升序排序的方法.分享给大家供大家参考,具体如下: # -*- coding:utf-8 -*- #! python2 list_one=[3,6,2,17,7,33,11,7] list_two=[1,2,3,7,4,2,17,33,11] list_new=list_one+list_two list=[] i=0 for x in list_new : if x not in list : list.append(x) list

  • python无序链表删除重复项的方法

    题目描述: 给定一个没有排序的链表,去掉重复项,并保留原顺序 如: 1->3->1->5->5->7,去掉重复项后变为:1->3->5->7 方法: 顺序删除 递归删除 1.顺序删除 由于这种方法采用双重循环对链表进行遍历,因此,时间复杂度为O(n**2) 在遍历链表的过程中,使用了常数个额外的指针变量来保存当前遍历的结点,前驱结点和被删除的结点,所以空间复杂度为O(1) #!/usr/bin/env python3 # -*- coding: utf-8

  • python实现求解列表中元素的排列和组合问题

    求解列表中元素的排列和组合问题这个问题之前就遇到过几次没有太留意,最近在做题的时候遇上挺多的排列组合问题的,想来有必要温习一下了,今天花点时间写一下,之前都是手工写的,后来知道可以直接使用python的内置模块就可以完成这个工作了,今天就使用python的itertools模块来完成这个工作,一共解决四个问题: 1.生成排列,列表中元素不允许重复出现 2.生成排列,列表中元素可以重复出现 3.生成组合,不限元素个数,列表中元素不允许重复出现 4.生成组合,不限元素个数,列表中元素可以重复出现 因

  • Python针对给定列表中元素进行翻转操作的方法分析

    本文实例讲述了Python针对给定列表中元素进行翻转操作的方法.分享给大家供大家参考,具体如下: 题目 给定一列表,翻转其中的元素,倒序输出 做法很简单,这里给出来两种做法,第一种最简单使用的是针对列表的切片操作,下面是具体实现 #!usr/bin/env python #encoding:utf-8 ''''' __Author__:沂水寒城 功能:翻转列表 ''' def inverse_list1(num_list): ''''' 翻转列表 ''' print num_list[::-1]

  • Python找出列表中出现次数最多的元素三种方式

    通过三种方式给大家介绍,具体详情如下所示: 方式一: 原理:创建一个新的空字典,用循环的方式来获取列表中的每一个元素,判断获取的元素是否存在字典中的key,如果不存在的话,将元素作为key,值为列表中元素的count # 字典方法 words = [ 'my', 'skills', 'are', 'poor', 'I', 'am', 'poor', 'I', 'need', 'skills', 'more', 'my', 'ability', 'are', 'so', 'poor' ] dict

随机推荐