时间:2021-05-22
先看一个需求
from collections import defaultdict"""需求: 统计user_list中字母出现的次数"""user_dict = {}user_list = ['A', 'B', 'C', 'A', 'C', 'C']# 第一种方式for item in user_list: if item not in user_dict: user_dict[item] = 1 else: user_dict[item] += 1print(user_dict) # {'A': 2, 'B': 1, 'C': 3}# 第二种方式user_dict = {}user_list = ['A', 'B', 'C', 'A', 'C', 'C']for item in user_list: user_dict.setdefault(item, 0) # 如果user_dict无item这个key,添加{item:0} , 如果有,不管. 而且这个方法性能比第一种方式好 user_dict[item] += 1 # item的value值累加1print(user_dict) # {'A': 2, 'B': 1, 'C': 3}# 第三种方式.使用defaultdictdefault_dict = defaultdict(int)user_list = ['A', 'B', 'C', 'A', 'C', 'C']for item in user_list: default_dict[item] += 1 # 使用这种方式,代码更简单,性能也更好print(default_dict) # defaultdict(<class 'int'>, {'A': 2, 'B': 1, 'C': 3})defaultdict的使用
由上面的示例可知,defaultdict会根据创建实例参数的类型生成一个对应类型的默认值,
这对于dict类型的数据结构而言,可以很好避免KeyError类型的错误 .
此外,我们还可以自定义defaultdict调用对象的数据结构,以满足我们实际需要
def person(): '''自定义一个可调用对象''' return { 'name': '', 'age': 0 }default_dict = defaultdict(person)default_dict['p']pass是不是很赞....
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
这篇文章给大家介绍Python中的defaultdict数据类型,具体内容如下所示:官方网址首先,defaultdict是dict的一个子类。通常Python中
三种方法:①直接使用dict②使用defaultdict③使用Counterps:`int()`函数默认返回0①dicttext="I'mahandsomebo
本文实例讲述了Python使用defaultdict读取文件各列的方法。分享给大家供大家参考,具体如下:#!/usr/bin/python"""USAGE:py
本文实例讲述了Python中defaultdict与lambda表达式用法。分享给大家供大家参考,具体如下:从教程中看到defaultdict是一个类,在一台装
本文实例讲述了python使用点操作符访问字典(dict)数据的方法。分享给大家供大家参考。具体分析如下:平时访问字典使用类似于:dict['name']的方式