Поскольку, кажется, никто не упомянул deepdiff
, я добавлю это здесь для полноты. Я нахожу это очень удобным для получения различий (вложенных) объектов в целом:
Монтаж
pip install deepdiff
Образец кода
import deepdiff
import json
dict_1 = {
"a": 1,
"nested": {
"b": 1,
}
}
dict_2 = {
"a": 2,
"nested": {
"b": 2,
}
}
diff = deepdiff.DeepDiff(dict_1, dict_2)
print(json.dumps(diff, indent=4))
Вывод
{
"values_changed": {
"root['a']": {
"new_value": 2,
"old_value": 1
},
"root['nested']['b']": {
"new_value": 2,
"old_value": 1
}
}
}
Примечание о приятной распечатке результата для проверки: приведенный выше код работает, если оба слова имеют одинаковые ключи атрибутов (возможно, с разными значениями атрибутов, как в примере). Тем не менее, если "extra"
атрибут присутствует является одним из диктов, происходит json.dumps()
сбой с
TypeError: Object of type PrettyOrderedSet is not JSON serializable
Решение: используйте diff.to_json()
and json.loads()
/ json.dumps()
to pretty-print:
import deepdiff
import json
dict_1 = {
"a": 1,
"nested": {
"b": 1,
},
"extra": 3
}
dict_2 = {
"a": 2,
"nested": {
"b": 2,
}
}
diff = deepdiff.DeepDiff(dict_1, dict_2)
print(json.dumps(json.loads(diff.to_json()), indent=4))
Вывод:
{
"dictionary_item_removed": [
"root['extra']"
],
"values_changed": {
"root['a']": {
"new_value": 2,
"old_value": 1
},
"root['nested']['b']": {
"new_value": 2,
"old_value": 1
}
}
}
Альтернатива: использование pprint
, результаты в другом формате:
import pprint
# same code as above
pprint.pprint(diff, indent=4)
Вывод:
{ 'dictionary_item_removed': [root['extra']],
'values_changed': { "root['a']": { 'new_value': 2,
'old_value': 1},
"root['nested']['b']": { 'new_value': 2,
'old_value': 1}}}
x == y
должно быть верно в соответствии со stackoverflow.com/a/5635309/186202