Skip to main content

An implementation of nested dictionaries

Project description

Python PyPI - Status PyPI - License PyPI - Python Version Read the Docs Test Codecov GitHub Release PyPI - Version


Lecteur francophone

En Python standard, il est possible d'avoir des dictionnaires à l'intérieur d'autres dictionnaires, créant ainsi des structures de données imbriquées. Cependant, bien que cette fonctionnalité existe, Python ne propose pas de moyens natifs pour rechercher facilement ou gérer les clés et valeurs dans des dictionnaires imbriqués complexes.

Mes recherches et tests sur des bibliothèques dédiées à la gestion des dictionnaires imbriqués m'ont conduit à plusieurs solutions, mais aucune n'a pleinement répondu à mes attentes. Le module qui s'en rapproche le plus est celui datant de 2015, disponible sur PyPI, mais il n'offre pas une architecture complète pour gérer les "objets de dictionnaires imbriqués" de manière fluide et robuste.

Cela m'a donc poussé à redévelopper un tel module, offrant une gestion plus complète et intuitive des dictionnaires imbriqués. Ce module facilite la manipulation, la recherche, et la gestion des clés et valeurs dans des structures de données plus complexes, en offrant des outils dédiés à cette tâche spécifique.

Qu'est-ce qu'un dictionnaire imbriqué ?

Un dictionnaire imbriqué est simplement un dictionnaire dont les valeurs peuvent elles-mêmes être des dictionnaires. Cela permet de créer des structures de données plus riches et hiérarchiques, où chaque "nœud" de la structure peut contenir des informations supplémentaires sous forme de dictionnaires, permettant ainsi de modéliser des données complexes de manière organisée et accessible.

Utilisation des clés imbriquées et gestion des hiérarchies dans les dictionnaires

Clés de différents types et utilisation des listes pour gérer la hiérarchie

Comme pour les dictionnaires classiques en Python, les clés dans un dictionnaire imbriqué doivent être hashables. Cela signifie que vous pouvez utiliser des types comme nombres, chaînes de caractères, ou tuples comme clés. Cependant, les listes ne sont pas hashables et ne peuvent pas être utilisées directement comme clés.

Accès aux valeurs imbriquées

Les dictionnaires imbriqués vous permettent de structurer vos données en plusieurs niveaux. Par exemple, pour accéder à une valeur dans un dictionnaire imbriqué, vous pouvez utiliser une séquence de clés qui représentera chaque niveau de la hiérarchie.

Par le biais des listes simples et non imbriquées, nous représentons cette hiérarchie d'imbrication.

Exemple d'accès imbriqué

Les deux expressions suivantes sont équivalentes pour accéder à une valeur dans un dictionnaire imbriqué :

dictionnaire[[1, "a", (2, 3)]] est equivalent à dictionnaire[1]["a"][(2, 3)]

English reader and ROW

In standard Python, dictionaries within dictionaries are possible, creating nested data structures. However, while this functionality exists, Python does not offer native features to easily search and manage keys and values within complex nested dictionaries.

My research and testing of libraries dedicated to managing nested dictionaries led me to several solutions, but none fully met my expectations. The module I found that came closest was one from 2015, available on PyPI, but it does not provide a complete architecture for managing "nested dictionary objects" in a smooth and robust way. This motivated me to redevelop such a module, offering a more complete and intuitive way to handle nested dictionaries. This new module makes it easier to manipulate, search, and manage keys and values in complex data structures by providing tools dedicated to this specific task.

What is a Nested Dictionary?

A nested dictionary is simply a dictionary where the values themselves are dictionaries. This allows for the creation of richer, hierarchical data structures where each "node" in the structure can hold additional information in the form of dictionaries, making it easier to model complex data in an organized and accessible way.

Using Nested Keys and Managing Hierarchies in Dictionaries

Keys of Different Types and Using Lists for Hierarchical Keys

Just like with standard dictionaries in Python, the keys in a nested dictionary must be hashable. This means you can use types such as numbers, strings, or even tuples as keys. However, lists are not hashable and cannot be used directly as keys.

Accessing Nested Values

Nested dictionaries allow you to structure your data over multiple levels. For example, to access a value in a nested dictionary, you can use a sequence of keys that represents each level of the hierarchy.

Using simple non nested lists is the way used to represents nested keys.

Nested Access Example

The following two expressions are equivalent for accessing a value in a nested dictionary:

dict[[1, "a", (2, 3)]] is equivalent to dict[1]["a"][(2, 3)]

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

ndict_tools-1.0.0.tar.gz (120.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ndict_tools-1.0.0-py3-none-any.whl (38.9 kB view details)

Uploaded Python 3

File details

Details for the file ndict_tools-1.0.0.tar.gz.

File metadata

  • Download URL: ndict_tools-1.0.0.tar.gz
  • Upload date:
  • Size: 120.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for ndict_tools-1.0.0.tar.gz
Algorithm Hash digest
SHA256 7cf315bb9b25ce60b0b624976eb0a25bc1873eb679fc6155168f9dd68165b92a
MD5 27dee6338385236d0e3e202a7ebd9acf
BLAKE2b-256 a5c2631744d82236441226667f51ec1b76001567564db599bbb563c5145a541b

See more details on using hashes here.

File details

Details for the file ndict_tools-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: ndict_tools-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 38.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.10.12

File hashes

Hashes for ndict_tools-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 781cef590a26c492f4c987bea8beb5fa25bebf1c487770a4f3a69dfa68f65d35
MD5 e23789e3088ea1a4d04fde6d0282630c
BLAKE2b-256 d2c517f5ee99b29cd95327c88935ef5683bb683310f76a92f2370308dd54f953

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page