6

这个问题中描述的问题是由我在尝试修复它的方法时犯的一个愚蠢的错误引起的,即在测试后不恢复所做的更改 - 但是该站点不允许我删除它。所以我建议你通过忽略它来节省一些更好地花在其他地方的时间。

在尝试最初建议使用自定义子类来解决打印问题的答案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
4

1 回答 1

20

文档说:

要使用自定义 JSONEncoder 子类(例如,覆盖 default() 方法以序列化其他类型的子类),请使用 cls kwarg指定它;否则使用 JSONEncoder。

print json.dumps(data_structure, cls=MyEncoder)

产量

{"layer1": {"layer2": {"layer3_2": "string", "layer3_1": "MyEncoder::NoIndent object"}}}
于 2012-11-06T13:13:24.827 回答