有时候拿到的pickle是文本数据,而文本中有bytes字符串,这时候不要把字符串转bytes类型,因为转了你会发现根本不是你想要的,只需eval()这个函数。
b_str = "b'\\x80\x03G@\x02ffffff.'" print('------原始------') print(type(b_str)) print(b_str) print('------转换------') ss = eval(b_str) print(type(ss)) print(ss) ss = pickle.loads(ss,encoding='bytes') print(ss)
注意,这个bytes格式的字符串,不能直接定义成字符串对象,需要把单斜线"\"转义为双斜线"\\",最少第一个出现的也要换成双斜线。(如果是文件中读取的则会自动转义)
以上是在py3下测试,py2下pickle.dumps()默认字符型并非bytes。