Maison > développement back-end > Tutoriel Python > Les clés d'un dictionnaire Python peuvent-elles être des tuples ?

Les clés d'un dictionnaire Python peuvent-elles être des tuples ?

silencement
Libérer: 2019-06-19 09:09:39
original
28351 Les gens l'ont consulté

Les clés d'un dictionnaire Python peuvent-elles être des tuples ?

Clés du dictionnaire Python

Les valeurs du dictionnaire n'ont aucune restriction et peuvent être n'importe quel objet Python, c'est-à-dire du standard objets définis par l'utilisateur. Tout objet est acceptable, mais les clés du dictionnaire sont restreintes au type.

Ne permet pas qu'une clé corresponde à plusieurs valeurs

Un principe doit être clair : chaque clé ne peut correspondre qu'à un seul élément. En d'autres termes : plusieurs valeurs correspondant à une clé ne sont pas autorisées (les objets conteneurs comme les listes, les tuples et autres dictionnaires sont autorisés). En cas de conflit de clés (c'est-à-dire qu'une clé de dictionnaire se voit attribuer une valeur à plusieurs reprises), la dernière affectation (la plus récente) est prise en compte. Python ne génère pas d'erreur en raison de clés conflictuelles dans le dictionnaire. Il ne vérifie pas les conflits de clés car si c'était le cas, il serait vérifié chaque fois qu'une paire clé-valeur est attribuée, ce qui prendrait un certain temps. quantité de mémoire.

>>> dict1 = {'foo':789, 'foo': 'xyz'} 
>>> dict1 
{'foo': 'xyz'} 
>>> dict1['foo'] = 123
>>> dict1 
{'foo': 123}
Copier après la connexion

Les clés doivent être hachables

La plupart des objets Python peuvent servir de clés, mais ils doivent être des objets hachables. Les types mutables comme les listes et les dictionnaires ne peuvent pas être utilisés comme clés car ils ne sont pas hachables. Tous les types immuables sont hachables, ils peuvent donc être utilisés comme clés de dictionnaire. Il convient de noter que les nombres avec des valeurs égales représentent la même clé, c'est-à-dire que les valeurs de hachage du nombre entier 1 et du nombre à virgule flottante 1.0 sont les mêmes et qu'il s'agit de la même clé.

En même temps, certains objets mutables (rarement) sont hachables, et ils peuvent être utilisés comme clés de dictionnaire, mais ils sont rares. Prenons, par exemple, une classe qui implémente la méthode spéciale __hash__(). Étant donné que la méthode __hash__() renvoie un entier, une valeur immuable est toujours utilisée (comme clé de dictionnaire). Pourquoi les clés doivent-elles être hachables ? L'interpréteur appelle une fonction de hachage pour calculer où stocker vos données en fonction de la valeur de la clé dans le dictionnaire. Si la clé est un objet mutable, sa valeur peut changer. Si la clé change, la fonction de hachage correspond à une adresse différente pour stocker les données. Si cela se produit, la fonction de hachage ne peut pas stocker ou récupérer de manière fiable les données pertinentes. La raison du choix des clés hachables est que leurs valeurs ne peuvent pas être modifiées.

Par exemple

d = {('a','b'):(3,7)}
Copier après la connexion

L'exemple ci-dessus utilise des tuples comme clés du dictionnaire. Vous pouvez voir qu'aucune erreur n'est signalée, indiquant que les tuples peuvent également être utilisés comme clés du dictionnaire.

Les nombres et les chaînes peuvent être utilisés comme clés de dictionnaire. Les tuples sont immuables mais ne peuvent pas être immuables, donc l'utilisation des tuples comme clés valides doit être restreinte : Si les tuples, seuls les paramètres immuables tels que les nombres et les chaînes sont inclus. comme clés valides dans le dictionnaire.

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!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal