sigmaepsilon.deepdict
is a lightweight Python library designed to handle nested dictionaries more easily, especially in cases where dictionaries are created dynamically. Its key feature is the DeepDict
class, which extends the regular dict to support nested layouts. It allows easy manipulation of deeply nested structures, array-like indexing, and automatic creation of deep dictionary levels without manually defining all parent keys. It is particularly useful in scenarios involving hierarchical data. The library also supports printing dictionaries as trees.
Consider the following simple dictionary
>>> d = {
... "a" : {"aa" : 1},
... "b" : 2,
... "c" : {"cc" : {"ccc" : 3}},
... }
This is what happens when you iterate through the values of it:
>>> list(d.values())
[{'aa': 1}, 2, {'cc': {'ccc': 3}}]
If you wrap it as a DeepDict
:
>>> from sigmaepsilon.deepdict import DeepDict
>>> dd = DeepDict.wrap(d)
>>> list(dd.values(deep=True))
[1, 2, 3]
The class allows array-like indexing, and when combined with the default factory, enables the creation of deep levels without manually defining all parent keys:
>>> data = DeepDict()
>>> data["a", 0, "b", 1, 5] = 10
Each subdirectory is aware about its parent container
>>> data["a", 0, "b"].key
"b"
>>> data["a", 0, "b"].address
['a', 0, 'b']
>>> data["a", 0, "b"].parent.key
0
Given that the asciitree
library is installed, it is also possible to print dictionaries (any kind) as a tree:
>>> from sigmaepsilon.deepdict import asciiprint
>>> d = {
... "a" : {"aa" : 1},
... "b" : 2,
... "c" : {"cc" : {"ccc" : 3}},
... }
>>> data = DeepDict.wrap(d)
>>> data.name = "Data"
>>> asciiprint(data)
Data
+-- a
+-- c
+-- cc
See the documentation for more examples and explanation on behaviour.
The documentation is built with Sphinx using the PyData Sphinx Theme and hosted on ReadTheDocs.
The library can be installed from PyPI using pip
on Python >= 3.10:
>>> pip install sigmaepsilon.deepdict
This package is licensed under the MIT license.