在python中,有没有什么方法/ class / module可以比较两个json对象并打印更改/差异?
我试过使用"json_tools“,它给出了相当好的结果,但是如果在两个json对象中存在具有不同顺序的元素的python列表,则diff会失败。
例如:
JSON 1:
{
'Person' :
{
'FName' : 'John',
'LName' : 'Rambo',
'Sex' : 'Male'
'Height' : '6 ft',
'Weight' : '90 KG',
'Children' :
[
{
'FName' : 'Anna',
'LName' : 'Rambo',
'Sex' : 'Female',
'Height' : '5 ft',
'Weight' : '55 KG',
},
{
'FName' : 'Jemmy',
'LName' : 'Rambo',
'Sex' : 'Male',
'Height' : '5 ft',
'Weight' : '60 KG',
}
]
}
}JSON 2:
{
'Person' :
{
'FName' : 'John',
'LName' : 'Rambo',
'Sex' : 'Male'
'Height' : '6 ft',
'Weight' : '90 KG',
'Children' :
[
{
'FName' : 'Jemmy',
'LName' : 'Rambo',
'Sex' : 'Male',
'Height' : '5 ft',
'Weight' : '60 KG',
},
{
'FName' : 'Anna',
'LName' : 'Rambo',
'Sex' : 'Female',
'Height' : '5 ft',
'Weight' : '55 KG',
}
]
}
}json diff显示两个json不匹配。从逻辑上讲,这些是相同的..
在python中有没有一个很好的json匹配和比较的方法?
发布于 2016-09-23 22:27:27
您可以使用jsondiff
from jsondiff import diff
diff(json1, json2)..。假设您已经使用示例中的json条目加载了json1和json2 (顺便说一句,您在“性别”条目后缺少逗号)。
发布于 2018-09-04 23:07:23
您可以在ignore_order=True中使用deepdiff
from deepdiff import DeepDiff
t1 = {1:1, 2:2, 3:3, 4:{"a":"hello", "b":[1, 2, 3]}}
t2 = {1:1, 2:2, 3:3, 4:{"a":"hello", "b":[1, 3, 2, 3]}}
ddiff = DeepDiff(t1, t2, ignore_order=True)
print (ddiff)
{}发布于 2013-07-12 13:34:46
在逻辑上它们是相同的。
他们不是。顺序在JSON数组中很重要。我不知道有什么工具会为你忽略订单。你可以试着在反序列化的结构上递归,把列表变成某种多集,把字典变成某种可哈希的、冻结的字典(所以你可以把它们放进多集),然后在上面运行你自己的diff例程。
https://stackoverflow.com/questions/17607640
复制相似问题