Маринованные свалки дают ценность для мусора
Привет, я использую JSON Encoder, где pickle.dumps() дает мне странный вывод. Выход приходит как:
"cdecimal Decimal p0 (S'2097369' p1 tp2 Rp3 .",
Пока должно быть: 2097369
Фрагмент кода:
class PythonObjectEncoder(JSONEncoder):
def default(self, obj):
if isinstance(obj, (list, dict, unicode, int, float, str, bool, type(None))):
return JSONEncoder.default(self, obj)
return pickle.dumps(obj)
def as_python_object(dct):
if '_python_object' in dct:
return pickle.loads('')
return dct
Может кто-нибудь сказать мне, что происходит не так и как я могу вернуть желаемое значение?
1 ответ
Я думаю, это то, что вы ищете. Типы, не поддерживаемые JSON, сериализуются в строку, используя pickle
и хранится в формате, указывающем, что это объект Python. object_hook
используется для распознавания этого формата и преобразования преобразованного объекта обратно в объект Python во время json.loads
:
from decimal import Decimal
import json
import pickle
class PythonObjectEncoder(json.JSONEncoder):
def default(self, obj):
if isinstance(obj, (dict,list,tuple,str,unicode,int,long,float,bool,type(None))):
return json.JSONEncoder.default(self,obj)
return {'_python_object_':pickle.dumps(obj)}
def as_python_object(dct):
if u'_python_object_' in dct:
return pickle.loads(dct[u'_python_object_'])
return dct
obj = {'a':1,'b':'string','c':1.2,'d':Decimal('123.456')}
print obj # original object
j = json.dumps(obj,cls=PythonObjectEncoder,indent=2)
print j # encoded object
obj = json.loads(j,object_hook=as_python_object)
print obj # decoded object
Выход:
{'a': 1, 'c': 1.2, 'b': 'string', 'd': Decimal('123.456')}
{
"a": 1,
"c": 1.2,
"b": "string",
"d": {
"_python_object_": "cdecimal\nDecimal\np0\n(S'123.456'\np1\ntp2\nRp3\n."
}
}
{u'a': 1, u'c': 1.2, u'b': u'string', u'd': Decimal('123.456')}