Avertissements Fromkeys : Comprendre le comportement de l'initialisation du dictionnaire
En Python, la méthode dict.fromkeys() est couramment utilisée pour créer un dictionnaire avec des clés spécifiées affectées à des listes vides. Cependant, une mauvaise interprétation de son comportement a conduit à des résultats inattendus.
Pourquoi fromkeys() est délicat
Quand une liste vide [] est fournie comme deuxième argument pour dicter .fromkeys(), toutes les valeurs du dictionnaire résultant pointent vers le même objet de liste. Cela signifie que toute modification d'une valeur affecte toutes les valeurs.
Solutions alternatives
Pour résoudre ce problème, les solutions suivantes sont recommandées :
Utilisez une compréhension de dictionnaire :
En Python 2.7 ou ci-dessus, une compréhension de dictionnaire est la solution la plus concise et la plus lisible :
data = {k: [] for k in range(2)}
Utiliser une compréhension de liste avec dict() :
Dans versions antérieures de Python, une compréhension de liste peut être transmise à dict() constructor :
data = dict([(k, []) for k in range(2)])
Utiliser une expression génératrice avec dict() :
Dans Python 2.4-2.6, une expression génératrice peut être utilisée avec dict(), et les parenthèses peuvent être omis :
data = dict((k, []) for k in range(2))
Exemple
L'exemple suivant illustre la différence entre le comportement par défaut de fromkeys() et les solutions recommandées :
# Default behavior of fromkeys() data = {} data = data.fromkeys(range(2), []) data[1].append('hello') print(data) # Output: {0: ['hello'], 1: ['hello']} # Using a dictionary comprehension data = {k: [] for k in range(2)} data[1].append('hello') print(data) # Output: {0: [], 1: ['hello']}
En comprenant les nuances de fromkeys(), les développeurs peuvent créer efficacement des dictionnaires de listes vides et conserver des clés individuelles adressage.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!