这是一个简单的问题,但我似乎无法弄清楚。我想获取从pickle.dumps()
输出的字节并将其转换为str
,并能够将其转换回与bytes
兼容,以便pickle.loads(string_thing)
可以恢复原始对象。 / p>
encoded = pickle.dumps(None)
string_encoded = to_string(encoded)
decoded = pickle.loads(safe_decoder(string_encoded))
我知道会有一个反对意见,“为什么要这么做?”对允许的类型的限制。
答案 0 :(得分:2)
@deceze提供了一个好主意:使用模块base64
及其功能.b64encode()
和.b64decode()
。
这里是一个例子:
>>> 'Álñó@'
'Álñó@'
>>> 'Álñó@'.encode()
b'\xc3\x81l\xc3\xb1\xc3\xb3@'
>>> base64.b64encode('Álñó@'.encode())
b'w4Fsw7HDs0A='
>>> base64.b64encode('Álñó@'.encode()).decode()
'w4Fsw7HDs0A='
现在在base64中有一个字符串。对于相反的过程:
>>> base64.b64encode('Álñó@'.encode()).decode().encode()
b'w4Fsw7HDs0A='
>>> base64.b64decode(base64.b64encode('Álñó@'.encode()).decode().encode())
b'\xc3\x81l\xc3\xb1\xc3\xb3@'
>>> base64.b64decode(base64.b64encode('Álñó@'.encode()).decode().encode()).decode()
'Álñó@'
对您有用吗?
使用pickle
的示例:
>>> original_obj = 456.5
>>> original_obj
456.5
>>> type(original_obj)
<class 'float'>
>>> intermediate_str = base64.b64encode(pickle.dumps(original_obj)).decode()
>>> intermediate_str
'gANHQHyIAAAAAAAu'
>>> new_obj = pickle.loads(base64.b64decode(intermediate_str.encode()))
>>> new_obj
456.5
>>> type(new_obj)
<class 'float'>
>>> original_obj == new_obj
True