DefaultDict
Defaultdict(int)
DefaultDict es una subclase de dict que proporciona un valor predeterminado para una clave inexistente. Vamos a crear un DefaultDict con valores predeterminados 0 en default_dict1.py y contar la frecuencia de aparición de las palabras en una frase:
from collections import defaultdict
sentence = "the quick brown fox jumps over the lazy dog"
word_count1 = defaultdict(int)
for word in sentence.split():
## Cuenta la frecuencia de aparición de las palabras
word_count1[word] += 1
print(dict(word_count1))
Luego, ejecute el script en la terminal:
python default_dict1.py
Salida:
{'the': 2, 'quick': 1, 'brown': 1, 'fox': 1, 'jumps': 1, 'over': 1, 'lazy': 1, 'dog': 1}
Si no hubiéramos usado DefaultDict, el código equivalente se vería así:
sentence = "the quick brown fox jumps over the lazy dog"
result = {}
for word in sentence.split():
if word in result:
result[word] += 1
else:
result[word] = 1
print(result)
Defaultdict(list)
A continuación, vamos a crear un DefaultDict con valores predeterminados [] en default_dict2.py y almacenar los números para cada letra:
from collections import defaultdict
data = [('a', 1), ('a', 1), ('a', 3), ('b', 1), ('b', 2), ('b', 3)]
word_count2 = defaultdict(list)
for (key,value) in data:
## Almacena los números para cada letra
word_count2[key].append(value)
print(dict(word_count2))
Luego, ejecute el script en la terminal:
python default_dict2.py
Salida:
{'a': [1, 1, 3], 'b': [1, 2, 3]}
Si no hubiéramos usado DefaultDict, el código equivalente se vería así:
data = [('a', 1), ('a', 1), ('a', 3), ('b', 1), ('b', 2), ('b', 3)]
result = {}
for (key, value) in data:
if key in result:
result[key].append(value)
else:
result[key] = [value]
print(result)
Defaultdict(set)
Finalmente, vamos a crear un DefaultDict con valores predeterminados set() en default_dict3.py y almacenar los números que no se repiten para cada letra:
from collections import defaultdict
data = [('a', 1), ('a', 1), ('a', 3), ('b', 1), ('b', 2), ('b', 3)]
word_count3 = defaultdict(set)
for (key,value) in data:
## Almacena los números que no se repiten para cada letra
word_count3[key].add(value)
print(dict(word_count3))
Luego, ejecute el script en la terminal:
python default_dict3.py
Salida:
{'a': {1, 3}, 'b': {1, 2, 3}}
Si no hubiéramos usado DefaultDict, el código equivalente se vería así:
data = [('a', 1), ('a', 1), ('a', 3), ('b', 1), ('b', 2), ('b', 3)]
result = {}
for (key, value) in data:
if key in result:
result[key].add(value)
else:
result[key] = {value}
print(result)