45 lines
961 B

"""
get/put functions that consume/produce Python lists using msgpack or pickle
to serialize.
First we try msgpack (it's faster). If that fails then we default to pickle.
"""
from __future__ import absolute_import
from .compatibility import pickle
try:
from pandas import msgpack
except ImportError:
try:
import msgpack
except ImportError:
msgpack = False
from .encode import Encode
from functools import partial
def dumps(x):
try:
return msgpack.packb(x, use_bin_type=True)
except:
return pickle.dumps(x, protocol=pickle.HIGHEST_PROTOCOL)
def loads(x):
try:
if msgpack.version >= (0, 5, 2):
unpack_kwargs = {'raw': False}
else:
unpack_kwargs = {'encoding': 'utf-8'}
return msgpack.unpackb(x, **unpack_kwargs)
except:
return pickle.loads(x)
def concat(lists):
return sum(lists, [])
Python = partial(Encode, dumps, loads, concat)