rekby f23ace9b7c Export python deepmerge library instead of mergedeep to github.com/ydb-platform/ydb for support python2 3 месяцев назад
..
.dist-info f23ace9b7c Export python deepmerge library instead of mergedeep to github.com/ydb-platform/ydb for support python2 3 месяцев назад
deepmerge f23ace9b7c Export python deepmerge library instead of mergedeep to github.com/ydb-platform/ydb for support python2 3 месяцев назад
tests f23ace9b7c Export python deepmerge library instead of mergedeep to github.com/ydb-platform/ydb for support python2 3 месяцев назад
LICENSE f23ace9b7c Export python deepmerge library instead of mergedeep to github.com/ydb-platform/ydb for support python2 3 месяцев назад
README.rst f23ace9b7c Export python deepmerge library instead of mergedeep to github.com/ydb-platform/ydb for support python2 3 месяцев назад
ya.make f23ace9b7c Export python deepmerge library instead of mergedeep to github.com/ydb-platform/ydb for support python2 3 месяцев назад

README.rst

=========
deepmerge
=========

.. image:: https://github.com/toumorokoshi/deepmerge/actions/workflows/python-package.yaml/badge.svg
:target: https://github.com/toumorokoshi/deepmerge/actions/workflows/python-package.yaml

A tools to handle merging of
nested data structures in python.

------------
Installation
------------

deepmerge is available on `pypi `_:

.. code-block:: bash

pip install deepmerge

-------
Example
-------

**Generic Strategy**

.. code-block:: python

from deepmerge import always_merger

base = {"foo": ["bar"]}
next = {"foo": ["baz"]}

expected_result = {'foo': ['bar', 'baz']}
result = always_merger.merge(base, next)

assert expected_result == result


**Custom Strategy**

.. code-block:: 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"]),
(set, ["union"])
],
# next, choose the fallback strategies,
# applied to all other types:
["override"],
# finally, choose the strategies in
# the case where the types conflict:
["override"]
)
base = {"foo": ["bar"]}
next = {"bar": "baz"}
my_merger.merge(base, next)
assert base == {"foo": ["bar"], "bar": "baz"}


You can also pass in your own merge functions, instead of a string.

For more information, see the `docs `_