DeepDiff 9.0.0 documentation!¶
DeepDiff is now part of Qluster.
If you’re building workflows around data validation and correction, Qluster gives your team a structured way to manage rules, review failures, approve fixes, and reuse decisions—without building the entire system from scratch.
Modules¶
The DeepDiff library includes the following modules:
DeepDiff For Deep Difference of 2 objects. DeepDiff
It returns 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 9-0-0¶
- migration note:
to_dict() and to_json() now accept a verbose_level parameter and always return a usable text-view dict. When the original view is ‘tree’, they default to verbose_level=2 for full detail. The old view_override parameter is removed. To get the previous results, you will need to pass the explicit verbose_level to to_json and to_dict if you are using the tree view.
Dropping support for Python 3.9
Support for python 3.14
Added support for callable
group_bythanks to echan5Added
FlatDeltaDictTypedDict forto_flat_dictsreturn typeFixed colored view display when all list items are removed thanks to yannrouillard
Fixed
hasattr()swallowingAttributeErrorin__slots__handling for objects with__getattr__thanks to tpvasconcelosFixed
ignore_order=Truemissing int-vs-float type changesFixed Delta producing phantom entries when items both move and change values with
iterable_compare_functhanks to devin13coxFixed
_convert_oversized_intsfailing on NamedTuplesFixed orjson
TypeErrorfor integers exceeding 64-bit rangeFixed parameter bug in
to_flat_dictswhereinclude_action_in_pathandreport_type_changeswere not being passed throughFixed
ignore_keysissue indetailed__dict__thanks to vitalis89Fixed logarithmic similarity type hint thanks to ljames8
Added
Fractionnumeric support thanks to akshat62
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
Importing¶
>>> 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
Supported data types¶
int, string, unicode, dictionary, list, tuple, set, frozenset, OrderedDict, NamedTuple, Numpy, custom objects and more!
References¶
- DeepDiff
DeepDiff- Basics
- Customized Diff
- Deep Distance
- Exclude Paths
- Include Paths
- Ignore Order
- Ignore Types Or Values
- Exclude Types
- Ignore String Type Changes
- Ignore Numeric Type Changes
- Ignore Type In Groups
- Ignore Type Subclasses
- Ignore UUID Types
- Ignore String Case
- Ignore Nan Inequality
- Ignore Private Variables
- Exclude Obj Callback
- Exclude Obj Callback Strict
- Include Obj Callback
- Include Obj Callback Strict
- Truncate Datetime
- Use Enum Value
- Numbers
- Optimizations
- Other Parameters
- Serialization
- Stats and Logging
- Troubleshoot
- View
- DeepSearch
- DeepHash
- Delta
- Diff to load in Delta
- Delta Path parameter
- Delta File parameter
- Flat Dict List
- Flat Rows List
- Delta Deserializer
- Delta Serializer
- Delta Serialize To Flat Dictionaries
- Delta Dump Safety
- Delta Mutate parameter
- Delta and Numpy
- Delta Raise Errors parameter
- Delta Safe To Import parameter
- Delta Verify Symmetry parameter
- Delta Force
- Always Include Values
- Extract
- Colored View
- Command Line
- Changelog
- Authors
- F.A.Q
- Support