Оскільки, здається, ніхто не згадав 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()
та json.loads()
/ json.dumps()
для симпатичного друку:
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