2016-08-25 4 views
6

Je continue à obtenir cette erreur quand je lance le code suivant en python 3:TypeError: un objet octets comme est nécessaire, non « str » - Pokemon aller pirater

fname1 = "auth_cache_%s" % username 
fname=fname1.encode(encoding='utf_8') 
#fname=fname1.encode() 
if os.path.isfile(fname,) and cached: 
    response = pickle.load(open(fname)) 
else: 
    response = self.heartbeat() 
    f = open(fname,"w") 
    pickle.dump(response, f) 

Voici l'erreur que je reçois :

File "C:\Users\Dorien Xia\Desktop\Pokemon-Go-Bot-Working-Hack-API-master\pgoapi\pgoapi.py", line 345, in login 
    response = pickle.load(open(fname)) 
TypeError: a bytes-like object is required, not 'str' 

J'ai essayé de convertir le fname1 en octets via la fonction de codage, mais il ne résout toujours pas le problème. Quelqu'un peut-il me dire ce qui ne va pas?

+1

Copie possible de [Using pickle.dump - TypeError: doit être str, pas bytes] (http://stackoverflow.com/questions/13906623/using-pickle-dump-typeerror-must-be-str-not- octets) –

Répondre

9

Vous devez ouvrir le fichier en mode binaire:

file = open(fname, 'rb') 
response = pickle.load(file) 
file.close() 

Et en écrivant:

file = open(fname, 'wb') 
pickle.dump(response, file) 
file.close() 
+0

Ehh, il me donne toujours une erreur: –

+0

TypeError: fichier non valide: <_io.BufferedReader name = 'auth_cache_mavengences'> –

+0

Il peut être un problème avec une autre partie du code. Merci quand même pour vôtre aide! –

4

En Python 3, vous devez appeler spécifiquement soit 'rb' ou 'wb'.

with open('C:\Users\Dorien Xia\Desktop\Pokemon-Go-Bot-Working-Hack-API-master\pgoapi\pgoapi.py', 'rb') as file: 
    data = pickle.load(file) 
0

Vous devez remplacer 'str' par 'bytes'. Essayez ceci:

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() 

with open(fname, 'r') as f: 
    obj = pickle.load(StrToBytes(f)) 
0

Je reviens à ce lien de débordement de pile, donc je poste la vraie réponse pour la prochaine fois que je viens le chercher:

PickleDB est foiré et doit être fixé.

Ligne 201 de pickledb.py

De:

simplejson.dump(self.db, open(self.loco, 'wb')) 

à:

simplejson.dump(self.db, open(self.loco, 'wt')) 

Problème résolu pour toujours.