1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67
|
# FlatDict
[](https://pypi.python.org/pypi/flatdict)
[](https://github.com/gmr/flatdict/actions)
[](https://codecov.io/github/gmr/flatdict?branch=master)
[](https://flatdict.readthedocs.org)
`FlatDict` and `FlatterDict` are dict classes that allow for single level,
delimited key/value pair mapping of nested dictionaries. You can interact with
`FlatDict` and `FlatterDict` like a normal dictionary and access child
dictionaries as you normally would or with the composite key.
*For example:*
```python
value = flatdict.FlatDict({'foo': {'bar': 'baz', 'qux': 'corge'}})
```
*would be the same as:*
```python
value == {'foo:bar': 'baz', 'foo:qux': 'corge'}
```
*values can be accessed as:*
```python
print(foo['foo:bar'])
# or
print(foo['foo']['bar'])
```
Additionally, lists and tuples are also converted into dicts using `enumerate()`,
using the `FlatterDict` class.
*For example:*
```python
value = flatdict.FlatterDict({'list': ['a', 'b', 'c']})
```
*will be the same as:*
```python
value == {'list:0': 'a', 'list:1': 'b', 'list:2': 'c'}
```
## API
Documentation is available at https://flatdict.readthedocs.io
## Versioning
This package attempts to use semantic versioning. API changes are indicated
by the major version, non-breaking improvements by the minor, and bug fixes
in the revision.
It is recommended that you pin your targets to greater or equal to the current
version and less than the next major version.
## Installation
```bash
pip install flatdict
```
|