用python3讀取python2的pickle資料方式
阿新 • • 發佈:2020-01-09
問題一:TypeError: a bytes-like object is required,not 'str'
解決:該問題屬於Python3和Python2的字串相容問題,資料檔案是在Python2下序列化的,使用Python3讀取時,需要將‘str'轉化為'bytes'。
picklefile=open('XXX.pkl','r') class StrToBytes: def __init__(self,fileobj): self.fileobj = fileobj def read(self,size): return self.fileobj.read(size).encode() def readline(self,size=-1): return self.fileobj.readline(size).encode() data=pickle.load(StrToBytes(picklefile))
問題二:UnicodeDecodeError: 'ascii' codec can't decode byte 0x90 in position 44: ordinal not in range(128)
解決:加上encoding編碼方式
pickle.load(StrToBytes(data_file),encoding='iso-8859-1')
附上完整的讀取程式碼:
import pickle class StrToBytes: def __init__(self,size=-1): return self.fileobj.readline(size).encode() read = open('XXX.pkl','r') data = pickle.load(StrToBytes(read),encoding='iso-8859-1') print(data)
以上這篇用python3讀取python2的pickle資料方式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。