看起来他们的行为方式完全相同。
>>> data
[('a', 'b'), {'a': 1, 'b': 2}, ['a', 'b'], 'a', 'b']
>>> json.dumps(data)
'[["a", "b"], {"a": 1, "b": 2}, ["a", "b"], "a", "b"]'
>>> tornado.escape.json_encode(data)
'[["a", "b"], {"a": 1, "b": 2}, ["a", "b"], "a", "b"]'
>>> json.loads(json.dumps(data))
[[u'a', u'b'], {u'a': 1, u'b': 2}, [u'a', u'b'], u'a', u'b']
>>> tornado.escape.json_decode(json.dumps(data))
[[u'a', u'b'], {u'a': 1, u'b': 2}, [u'a', u'b'], u'a', u'b']
答案 0 :(得分:14)
有时阅读the source code:
是有用的def json_encode(value):
return json.dumps(value).replace("</", "<\\/")
def json_decode(value):
return json.loads(to_basestring(value))
def to_basestring(value):
if isinstance(value, _BASESTRING_TYPES):
return value
assert isinstance(value, bytes_type)
return value.decode("utf-8")
python 3.x主要需要 to_basestring
以确保value
的类型为str
,而不是bytes
,因为json.loads
无法处理后者。