a toolset to deeply merge python dictionaries.
Project description
# deepmerge
A tools to handle merging of
nested data structures in python.
## Example
```python
from deepmerge import Merger
my_merger = Merger(
# pass in a list of tuple, with the
# strategies you are looking to apply
# to each type.
[
(list, ["append"]),
(dict, ["merge"])
],
# next, choose the fallback strategies,
# applied to all other types:
["override"],
# finally, choose the strategies in
# the case where the types conflict:
["override"]
)
```
Strategies are passed as a list, and the
merge runs through each strategy sequentially,
and raises an exception if none are able to resolve
the merge.
You can also pass in your own merge functions, instead of a string.
Your function should take the arguments of (merger, path, base_value, value_to_merge_in).
A default merge does not exist, due to the
numerous choices that have to be made for every
merger. However, some very generic mergers are supplied:
* always_merger: will never raise a merge exception, and
will merge when possible.
* merge_or_raise: will merge when possible, raise an exception
when there is a conflict.
The best resource for now is the unit tests.
A tools to handle merging of
nested data structures in python.
## Example
```python
from deepmerge import Merger
my_merger = Merger(
# pass in a list of tuple, with the
# strategies you are looking to apply
# to each type.
[
(list, ["append"]),
(dict, ["merge"])
],
# next, choose the fallback strategies,
# applied to all other types:
["override"],
# finally, choose the strategies in
# the case where the types conflict:
["override"]
)
```
Strategies are passed as a list, and the
merge runs through each strategy sequentially,
and raises an exception if none are able to resolve
the merge.
You can also pass in your own merge functions, instead of a string.
Your function should take the arguments of (merger, path, base_value, value_to_merge_in).
A default merge does not exist, due to the
numerous choices that have to be made for every
merger. However, some very generic mergers are supplied:
* always_merger: will never raise a merge exception, and
will merge when possible.
* merge_or_raise: will merge when possible, raise an exception
when there is a conflict.
The best resource for now is the unit tests.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
deepmerge-0.0.1.tar.gz
(3.6 kB
view hashes)
Built Distribution
Close
Hashes for deepmerge-0.0.1-py2.py3-none-any.whl
Algorithm | Hash digest | |
---|---|---|
SHA256 | 0714dd0d3a81b354729e60643f713fef83ad25a4326b42c343bfd58e1b0ae3e7 |
|
MD5 | 5043d6a04063591536e7430ade0a9e27 |
|
BLAKE2b-256 | c0b0ad05e108076ab643864f35ddf014964ee24fbad54589c1f895b26d3e4a77 |