这个问题中描述的问题是由我在尝试修复它的方法时犯的一个愚蠢的错误引起的,即在测试后不恢复所做的更改 - 但是该站点不允许我删除它。所以我建议你通过忽略它来节省一些更好地花在其他地方的时间。
在尝试最初建议使用自定义子类来解决打印问题的答案JSONEncoder
时,我发现文档在Extending JSONEncoder:部分中建议执行的操作似乎不起作用。这是我的代码,它ComplexEncoder
也是在文档的该部分中的示例之后设计的。
import json
class NoIndent(object):
def __init__(self, value):
self.value = value
class MyEncoder(json.JSONEncoder):
def default(self, obj):
print 'MyEncoder.default() called'
if isinstance(obj, NoIndent):
return 'MyEncoder::NoIndent object' # hard code string for now
else:
return json.JSONEncoder.default(self, obj)
data_structure = {
'layer1': {
'layer2': {
'layer3_1': NoIndent([{"x":1,"y":7},{"x":0,"y":4},{"x":5,"y":3},{"x":6,"y":9}]),
'layer3_2': 'string'
}
}
}
print json.dumps(data_structure, default=MyEncoder)
这是导致的回溯:
Traceback (most recent call last):
File "C:\Files\PythonLib\Stack Overflow\json_parsing.py", line 26, in <module>
print json.dumps(data_structure, default=MyEncoder)
File "E:\Program Files\Python\lib\json\__init__.py", line 238, in dumps
**kw).encode(obj)
File "E:\Program Files\Python\lib\json\encoder.py", line 201, in encode
chunks = self.iterencode(o, _one_shot=True)
File "E:\Program Files\Python\lib\json\encoder.py", line 264, in iterencode
return _iterencode(o, 0)
RuntimeError: maximum recursion depth exceeded