在以下代码中:
>>> import pickle
>>>
>>> class Thing:
def __init__(self):
self.name = "stackoverflow"
self.age = 11
>>> a = pickle.dumps(Thing())
>>> a
b'\x80\x03c__main__\nThing\nq\x00)\x81q\x01}q\x02(X\x04\x00\x00\x00nameq\x03X\r\x00\x00\x00stackoverflowq\x04X\x03\x00\x00\x00ageq\x05K\x0bub.'
>>> str(a)
"b'\\x80\\x03c__main__\\nThing\\nq\\x00)\\x81q\\x01}q\\x02(X\\x04\\x00\\x00\\x00nameq\\x03X\\r\\x00\\x00\\x00stackoverflowq\\x04X\\x03\\x00\\x00\\x00ageq\\x05K\\x0bub.'"
我的问题是,如何将str(a)
转换回a
,因为一旦发生转换,我就可以轻松地使用pickle.loads()
解码
我转换为字符串的原因是,我希望将str(a)
字符串添加到另一个将进一步“被腌制”的字符串中。我见过的大多数其他文章都假定字节已经是字符串或字符串到字节转换的编码,而这都不是。
答案 0 :(得分:0)
以下内容似乎有效,因为任意二进制字符串都是有效的latin1
,始终可以将其解码为Unicode,然后再次编码回原始字符串(如{{3}在this answer中指出的那样) }。
import pickle
class Thing:
def __init__(self):
self.name = "stackoverflow"
self.age = 11
a = pickle.dumps(Thing())
str_a = a.decode('latin1')
b = str_a.encode('latin1')
assert a == b