我正在使用jsondiff库,该库返回以下结果:
a = {'TIERS': {delete: ['APP']}}
我不知道这是如何有效地表达dict(或JSON)的?是否应该因为
delete
不在引号中而失败?但是,这似乎是有效的字典。这是完整的库文件:https://github.com/ZoomerAnalytics/jsondiff/blob/master/jsondiff/init.py
图书馆的相关部分(至少可以收集到):
def emit_dict_diff(self, a, b, s, added, changed, removed):
if s == 0.0:
return b
elif s == 1.0:
return {}
else:
d = {}
if added:
d[insert] = added
if changed:
d[update] = changed
if removed:
d[delete] = list(removed.keys())
当我为此库使用转储(json.dump输出)选项时,结果是:
a = '{"TIERS": {"$delete": ["APP"]}}'
我在这种类型的语法上找不到任何东西,并且意识到这可能是可以谷歌搜索的,如果对此问题感到懒惰,对不起。
编辑:
python 3.6+
jsondiff库用作
a=jsondiff.diff(json1,json2,load=True)
最佳答案
在jsondiff.__init__.py
文件的第6行上:
from .symbols import *
请注意,不建议使用splat符号导入整个模块,因为除其他原因外,它使代码更难阅读。
在
.symbols
中,在第14行上定义了delete
:delete = Symbol('delete')
Symbol
类本身在同一模块的第2行中定义。class Symbol(object):
def __init__(self, label):
self.label = label
def __repr__(self):
return self.label
def __str__(self):
return "$" + self.label
如果要使用变量创建字典,例如
b
,它看起来像这样:b = 'two'
d = {'one': 1, b: 2}
>>> d
{'one': 1, 'two': 2}
但是,如果您使用一个简单的类,它将看起来像这样:
class Sym(object):
def __init__(self, label):
self.label = label
b = Sym('test')
d = {'one': 1, b: 2}
>>> d
{<__main__.Sym at 0x1a194be240>: 2, 'one': 1}
添加
__repr__
dunder方法将使此方法更具可读性:class Sym(object):
def __init__(self, label):
self.label = label
def __repr__(self):
return self.label
b = Sym('test')
d = {'one': 1, b: 2}
>>> d
{'one': 1, test: 2}
最后的
__str__
方法在转换为字符串时(例如在打印时)会在标签前加上美元符号。class Sym(object):
def __init__(self, label):
self.label = label
def __repr__(self):
return self.label
def __str__(self):
return "$" + self.label
b = Sym('test')
d = {'one': 1, b: 2}
>>> d
{test: 2, 'one': 1}
for key in d.keys():
print(key)
# Output:
# $test
# one