python - 从 DeepDiff 结果构造 python 字典

标签 python dictionary deep-diff

我有一个 DeepDiff 结果,它是通过比较两个 JSON 文件获得的。我必须从 deepdiff 结果构建一个 python 字典,如下所示。

json1 = {"spark": {"ttl":3, "poll":34}}
json2 = {"spark": {"ttl":3, "poll":34, "toll":23}, "cion": 34}

deepdiffresult = {'dictionary_item_added': {"root['spark']['toll']", "root['cion']"}}

expecteddict = {"spark" : {"toll":23}, "cion":34}

如何实现?

最佳答案

可能有更好的方法来做到这一点。但您可以解析返回的字符串,并将新字典与您想要的结果链接在一起。

json1 = {"spark": {"ttl":3, "poll":34}}
json2 = {"spark": {"ttl":3, "poll":34, "toll":23}, "cion": 34}
deepdiffresult = {'dictionary_item_added': {"root['spark']['toll']", "root['cion']"}}
added = deepdiffresult['dictionary_item_added']

def convert(s, j):
    s = s.replace('root','')
    s = s.replace('[','')
    s = s.replace("'",'')
    keys = s.split(']')[:-1]
    d = {}
    for k in reversed(keys):
        if not d:
            d[k] = None
        else:
            d = {k: d}
    v = None
    v_ref = d
    for i, k in enumerate(keys, 1):
        if not v:
            v = j.get(k)
        else:
            v = v.get(k)
        if i<len(keys):
            v_ref = v_ref.get(k)
    v_ref[k] = v
    return d

added_dict = {}
for added_str in added:
    added_dict.update(convert(added_str, json2))

added_dict
#returns:
{'cion': 34, 'spark': {'toll': 23}}

关于python - 从 DeepDiff 结果构造 python 字典,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49611771/

相关文章:

python - 使用 Jupyter Notebook 从 ipywidget 函数定义全局变量

python - Sacred - 将所有参数作为一个参数传递

android - 完全困惑试图整合 map ......最好的前进方式?

python - 从终端停止 python 脚本

python - Django 多个数据库,Django 最初是否连接到所有数据库?

python - Pandas Dataframe 中的频率词典

C# - 从现有字典创建列表

python - 如何从深度差异中完全排除 "type_changes",因为我只关心值的变化?

python - 如何使 DeepDiff 输出人类可读?