Implémentation d'une sous-classe de dict et remplacement de la méthode __missing__ est une approche créative pour créer dictionnaires imbriqués. Cette méthode permet d'intercepter et de gérer les clés manquantes avec élégance. Voici comment cela fonctionne :
Voici un exemple d'implémentation de Vividict :
class Vividict(dict): def __missing__(self, key): value = self[key] = type(self)() return value
Utilisation cette sous-classe, vous pouvez créer des dictionnaires imbriqués à la volée :
d = Vividict() d['foo']['bar'] = 1 d['foo']['baz'] = 2 print(d) # {'foo': {'bar': 1, 'baz': 2}}
Cette approche offre une syntaxe claire pour remplir les dictionnaires imbriqués et simplifie le processus de création de structures hiérarchiques complexes.
En plus d'utiliser une sous-classe personnalisée avec __missing__, voici quelques autres alternatives pour les dictionnaires imbriqués :
1. dict.setdefault :
L'utilisation de dict.setdefault fournit un moyen concis de créer des dictionnaires imbriqués, mais la syntaxe peut être verbeuse pour les structures complexes.
d = {} d.setdefault('foo', {}).setdefault('bar', []).append(1) d.setdefault('foo', {}).setdefault('baz', []).append(2) print(d) # {'foo': {'bar': [1], 'baz': [2]}}
2. Defaultdict auto-vivifié :
defaultdict du module de collections peut être utilisé pour créer un dictionnaire auto-vivifié qui crée automatiquement des dictionnaires imbriqués selon les besoins. Cependant, cette approche peut conduire à une sortie encombrée lors du débogage ou de l'inspection des données.
from collections import defaultdict def vivdict(): return defaultdict(vivdict) d = vivdict() d['foo']['bar'] = 1 d['foo']['baz'] = 2 print(d) # defaultdict(...defaultdict(...defaultdict(...))), etc.
3. Clés de tuple :
Au lieu d'utiliser des dictionnaires imbriqués, envisagez d'utiliser des tuples comme clés. Cette approche simplifie les itérations et les agrégations, mais peut conduire à un code syntaxiquement plus complexe pour la gestion des sous-ensembles du dictionnaire.
d = {('foo', 'bar'): 1, ('foo', 'baz'): 2}
En ce qui concerne les performances, dict .setdefault est généralement le plus efficace pour le code de production. Cependant, pour une utilisation interactive où la vitesse d'exécution est moins critique, Vividict peut fournir une solution plus pratique et plus lisible.
Implémentation de dictionnaires imbriqués avec une sous-classe et __missing__ offre une approche puissante et flexible qui peut être adaptée à des cas d'utilisation spécifiques. Bien que cela puisse introduire certains pièges potentiels, il offre également des avantages en termes de lisibilité du code et de manipulation des données. Des méthodes alternatives, telles que dict.setdefault et defaultdict auto-vivifié, servent leurs propres objectifs avec différents degrés de performances et de lisibilité de sortie.
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!