Python字典列表去重

Python字典列表去重

  • 最近在写代码时老是遇到 字典列表 的去重,想当然的就用上了 set(),哈哈哈哈哈直接上代码

    list_a = [{"name": "Tom", "age": 18}, {"name": "Jerry", "age": 18}, {"name": "Tom", "age": 18}]
    unique_list = list(list_a)
    print(unique_list)
    
  • 结果

    TypeError: unhashable type: 'dict'
    

    set / dict 使用 hash 值进行索引,也即其要求欲存储的元素有可哈希的要求,而列表中的元素为 dict
    Python debug——TypeError: unhashable type(list/set/dict)

  • 那就暴力去重吧

    list_a = [{"name": "Tom", "age": 18}, {"name": "Jerry", "age": 18}, {"name": "Tom", "age": 18}]
    unique_list = []
    for item in sorted(list_a, key=lambda x: x["name"]):
        if item not in unique_list:
            unique_list.append(item)
    print(unique_list)
    

    刚好学习一下时间复杂度 & 空间复杂度,处理列表前给排序上,平庸写法,结果不会错

    [{'name': 'Jerry', 'age': 18}, {'name': 'Tom', 'age': 18}]
    

    我当然不可能这么平庸,继续冲浪新方法,列表中相同的字典去重

    def list_dict_duplicate_removal(data_list):
    """
    列表中字典去重函数
    :param data_list: 嵌套字典的列表 如:[{"a":1},{"b":2}]
    :return:
    """
    run_function = lambda x, y: x if y in x else x + [y]
    from functools import reduce
    # reduce为python内置函数
    return reduce(run_function, [[], ] + data_list)
    
  • 简化成一行代码

    list_a = [{"name": "Tom", "age": 18}, {"name": "Jerry", "age": 18}, {"name": "Tom", "age": 18}]
    unique_list = functools.reduce(lambda x, y: y in x and x or x + [y], list_a, [])
    

    结果没问题,处理得很完美,👍

    [{'name': 'Tom', 'age': 18}, {'name': 'Jerry', 'age': 18}]
    

    不知道大伙看代码会不会骂我,反正我同事已经骂了,装神弄鬼,哈哈哈哈哈。不过我觉得多用些不一样的东西是好的,熟能生巧,日复一日cv真的累了。回到代码,其实就是functools.reduce() 再加上 and or 代替 三元表达式 ,🔚

  • 4
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值