【发布时间】:2015-08-08 18:40:40
【问题描述】:
我需要将 Python3 对象腌制为我想从 Travis CI 构建中的环境变量中解压缩的字符串。问题是我似乎无法在 Python3 中找到一种方法来腌制可移植字符串(unicode):
import os, pickle
from my_module import MyPickleableClass
obj = {'cls': MyPickleableClass, 'other_stuf': '(...)'}
pickled = pickle.dumps(obj)
# raises TypeError: str expected, not bytes
os.environ['pickled'] = pickled
# raises UnicodeDecodeError: 'utf-8' codec can't decode byte 0xbb (...)
os.environ['pickled'] = pickled.decode('utf-8')
pickle.loads(os.environ['pickled'])
有没有办法将复杂的对象(如datetime.datetime)序列化为 unicode 或 Python3 中的其他字符串表示形式,我可以将其传输到不同的机器并反序列化?
更新
我已经测试了@kindall 建议的解决方案,但pickle.dumps(obj, 0).decode() 引发了UnicodeDecodeError。尽管如此,base64 方法仍然有效,但它需要一个额外的解码/编码 步骤。该解决方案适用于 Python2.x 和 Python3.x。
# encode returns bytes so it needs to be decoded to string
pickled = pickle.loads(codecs.decode(pickled.encode(), 'base64')).decode()
type(pickled) # <class 'str'>
unpickled = pickle.loads(codecs.decode(pickled.encode(), 'base64'))
【问题讨论】:
-
类似 JSON 的东西?
-
是的,如果可能的话,我更喜欢像 JSON 这样更安全的格式。 Pickles 与可执行代码一样好,并且从 envvar 中运行任意代码对我来说似乎很脏,即使由于应用程序的原因,它目前还不是安全漏洞。在您真正需要这种灵活性之前,不要诉诸泡菜;你当然不喜欢
datetime。
标签: python python-3.x serialization unicode