DeepDiff 8.1.1 documentation!

Modules

The DeepDiff library includes the following modules:

  • DeepDiff For Deep Difference of 2 objects. DeepDiff

    It return the deep Difference of python objects. It can also be used to take the distance between objects. Deep Distance

  • DeepSearch Search for objects within other objects. DeepSearch

  • DeepHash Hash any object based on their content even if they are not “hashable” in Python’s eyes. DeepHash

  • Delta Delta of objects that can be applied to other objects. Imagine git commits but for structured data. Delta

  • Extract For extracting a path from an object Extract

  • Commandline Most of the above functionality is also available via the commandline module Command Line

What Is New

DeepDiff 8-1-0

  • Removing deprecated lines from setup.py

  • Added prefix option to pretty()

  • Fixes hashing of numpy boolean values.

  • Fixes slots comparison when the attribute doesn’t exist.

  • Relaxing orderly-set reqs

  • Added Python 3.13 support

  • Only lower if clean_key is instance of str

  • Fixes issue where the key deep_distance is not returned when both compared items are equal

  • Fixes exclude_paths fails to work in certain cases

  • exclude_paths fails to work

  • Fixes to_json() method chokes on standard json.dumps() kwargs such as sort_keys

  • to_dict() method chokes on standard json.dumps() kwargs

  • Fixes accessing the affected_root_keys property on the diff object returned by DeepDiff fails when one of the dicts is empty

  • Fixes accessing the affected_root_keys property on the diff object returned by DeepDiff fails when one of the dicts is empty

DeepDiff 8-0-1

  • Bugfix. Numpy should be optional.

DeepDiff 8-0-0

  • With the introduction of threshold_to_diff_deeper, the values returned are different than in previous versions of DeepDiff. You can still get the older values by setting threshold_to_diff_deeper=0. However to signify that enough has changed in this release that the users need to update the parameters passed to DeepDiff, we will be doing a major version update.

  • use_enum_value=True makes it so when diffing enum, we use the enum’s value. It makes it so comparing an enum to a string or any other value is not reported as a type change.

  • threshold_to_diff_deeper=float is a number between 0 and 1. When comparing dictionaries that have a small intersection of keys, we will report the dictionary as a new_value instead of reporting individual keys changed. If you set it to zero, you get the same results as DeepDiff 7.0.1 and earlier, which means this feature is disabled. The new default is 0.33 which means if less that one third of keys between dictionaries intersect, report it as a new object.

  • Deprecated ordered-set and switched to orderly-set. The ordered-set package was not being maintained anymore and starting Python 3.6, there were better options for sets that ordered. I forked one of the new implementations, modified it, and published it as orderly-set.

  • Added use_log_scale:bool and log_scale_similarity_threshold:float. They can be used to ignore small changes in numbers by comparing their differences in logarithmic space. This is different than ignoring the difference based on significant digits.

  • json serialization of reversed lists.

  • Fix for iterable moved items when iterable_compare_func is used.

  • Pandas and Polars support

DeepDiff 7-0-0

  • DeepDiff 7 comes with an improved delta object. Delta to flat dictionaries have undergone a major change. We have also introduced Delta serialize to flat rows.

  • Subtracting delta objects have dramatically improved at the cost of holding more metadata about the original objects.

  • When verbose=2, and the “path” of an item has changed in a report between t1 and t2, we include it as new_path.

  • path(use_t2=True) returns the correct path to t2 in any reported change in the tree view

  • Python 3.7 support is dropped and Python 3.12 is officially supported.

DeepDiff 6-7-1

DeepDiff 6-7-0

  • Delta can be subtracted from other objects now.

  • verify_symmetry is deprecated. Use bidirectional instead.

  • Always Include Values flag in Delta can be enabled to include values in the delta for every change.

  • Fix for Delta.__add__ breaks with esoteric dict keys.

  • Delta Load From Flat Dictionaries can be used to load a delta from the list of flat dictionaries.

DeepDiff 6-6-1

DeepDiff 6-6-0

Tutorials

Tutorials can be found on Zepworks blog

Installation

Install from PyPi:

pip install deepdiff

If you want to use DeepDiff from commandline:

pip install "deepdiff[cli]"

If you want to improve the performance of DeepDiff with certain processes such as json serialization:

pip install "deepdiff[optimize]"

Read about DeepDiff optimizations at Optimizations

>>> from deepdiff import DeepDiff  # For Deep Difference of 2 objects
>>> from deepdiff import grep, DeepSearch  # For finding if item exists in an object
>>> from deepdiff import DeepHash  # For hashing objects based on their contents
>>> from deepdiff import Delta  # For creating delta of objects that can be applied later to other objects.
>>> from deepdiff import extract  # For extracting a path from an object

Note

if you want to use DeepDiff via commandline, make sure to run:: pip install “deepdiff[cli]”

Then you can access the commands via:

  • DeepDiff

$ deep diff --help
  • Delta

$ deep patch --help
  • grep

$ deep grep --help
  • extract

$ deep extract --help

int, string, unicode, dictionary, list, tuple, set, frozenset, OrderedDict, NamedTuple, Numpy, custom objects and more!

References

Indices and tables