天天看點

Python dict和defaultdict使用執行個體解析

先看一個需求

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] += 1

print(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值累加1

print(user_dict) # {'A': 2, 'B': 1, 'C': 3}

# 第三種方式.使用defaultdict
default_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的使用

Python dict和defaultdict使用執行個體解析
Python dict和defaultdict使用執行個體解析
Python dict和defaultdict使用執行個體解析

由上面的示例可知,defaultdict會根據建立執行個體參數的類型生成一個對應類型的預設值,

這對于dict類型的資料結構而言,可以很好避免KeyError類型的錯誤 .

此外,我們還可以自定義defaultdict調用對象的資料結構,以滿足我們實際需要

def person():
  '''自定義一個可調用對象'''
  return {
    'name': '',
    'age': 0
  }
default_dict = defaultdict(person)
default_dict['p']
pass           

複制

Python dict和defaultdict使用執行個體解析

是不是很贊….

以上就是本文的全部内容,希望對大家的學習有所幫助。