Changelog History
Page 1
-
v9.0.0 Changes
March 30, 2026migration note:
to_dict()andto_json()now accept averbose_levelparameter and always return a usable text-view dict. When the original view is'tree', they default toverbose_level=2for full detail. The oldview_overrideparameter is removed. To get the previous results, you will need to pass the explicit verbose_level toto_jsonandto_dictif 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 type🛠 Fixed colored view display when all list items are removed thanks to yannrouillard
Fixed
hasattr()swallowingAttributeErrorin__slots__handling for objects with__getattr__thanks to tpvasconcelos🛠 Fixed
ignore_order=Truemissing int-vs-float type changesAlways use t1 path for reporting thanks to devin13cox
Fixed
_convert_oversized_intsfailing on NamedTuples🛠 Fixed 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 vitalis89🛠 Fixed logarithmic similarity type hint thanks to ljames8
-
v8.6.2 Changes
March 25, 20268.6.2 - Fix (CVE-2025-58367)
-
v8.6.1 Changes
September 04, 2025DeepDiff 8-6-1
- 🔒 Patched security vulnerability in the Delta class which was vulnerable to class pollution via its constructor, and when combined with a gadget available in DeltaDiff itself, it could lead to Denial of Service and Remote Code Execution (via insecure Pickle deserialization).
-
v8.5.0 Changes
May 09, 2025- ⚡️ Updating deprecated pydantic calls
- Switching to pyproject.toml
- Fix for moving nested tables when using iterable_compare_func. by
- 🛠 Fix recursion depth limit when hashing numpy.datetime64
- Moving from legacy setuptools use to pyproject.toml
-
v8.4.1 Changes
March 17, 2025- pytz is not required.
-
v8.4.0 Changes
March 16, 2025- ➕ Adding BaseOperatorPlus base class for custom operators
- 0️⃣ default_timezone can be passed now to set your default timezone to something other than UTC.
- 🆕 New summarization algorithm that produces valid json
- 👍 Better type hint support
-
v8.1.1 Changes
December 16, 2024➕ Adding Python 3.13 to setup.py
-
v8.1.0 Changes
December 16, 2024- 🗄 Removing deprecated lines from setup.py
- ➕ Added
prefixoption topretty() - 🛠 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 #504
- 🛠 Fixes issue where the key deep_distance is not returned when both compared items are equal #510
- 🛠 Fixes exclude_paths fails to work in certain cases
- exclude_paths fails to work #509
- Fixes to_json() method chokes on standard json.dumps() kwargs such as sort_keys
- to_dict() method chokes on standard json.dumps() kwargs #490
- 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 #508
-
v8.0.1 Changes
October 24, 2024🚚 8.0.1 - extra import of numpy is removed
-
v8.0.0 Changes
August 27, 2024With 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 settingthreshold_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=Truemakes 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=floatis a number between 0 and 1. When comparing dictionaries that have a small intersection of keys, we will report the dictionary as anew_valueinstead 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-setand switched toorderly-set. Theordered-setpackage 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 asorderly-set. - 🌲 Added
use_log_scale:boolandlog_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_funcis used. - 👍 Pandas and Polars support.
-