1. 程式人生 > 程式設計 >用python3讀取python2的pickle資料方式

用python3讀取python2的pickle資料方式

問題一: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資料方式就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。