Le problème que j'ai est quand j'essaye de charger l'objet pickled. J'ai essayé d'utiliser les deux pickle.loads
et pickle.load
Voici les résultats:
pickle.loads
:
TypeError: 'str' ne prend pas en charge l'interface de tampon
pickle.load
:
TypeError: le fichier doit avoir des attributs 'read' et 'readline'
Quelqu'un peut-il me dire ce que je fais de mal dans ce processus?
Elif str(parser) == 'SwissWithdrawn_Parser':
# swissprot name changes
print('Gathering SwissProt update info...')
cache_hits = 0
cache_misses = 0
files = set()
for f in os.listdir('out/cache/'):
if os.path.isfile('out/cache/'+f):
files.add(f)
for name in sp_lost_names:
cached = False
url = 'http://www.uniprot.org/uniprot/?query=mnemonic%3a'+name+ \
'+active%3ayes&format=tab&columns=entry%20name'
hashed_url = str(hash(url))
################### For Testing Only - use cache ##################
if hashed_url in files:
cached = True
cache_hits += 1
content = pickle.loads('out/cache/' +hashed_url) # <-- problematic line
else:
cache_misses += 1
content = urllib.request.urlopen(url)
# get the contents returned from the HTTPResponse object
content_list = [x.decode().strip() for x in content.readlines()]
if not cached:
with open('out/cache/'+hashed_url, 'wb') as fp:
pickle.dump(content_list, fp)
####################################################################
# no replacement
if len(content_list) is 0:
change_log['swiss-names'] =
{ name : 'withdrawn' }
# get the new name
else:
new_name = content_list[1]
change_log['swiss-names'] =
{ name : new_name }
Vous devez d'abord lire le fichier (en tant que binaire bytes
) et utiliser pickle.loads()
, ou passer un objet fichier ouvert à la pickle.load()
commander. Ce dernier est préférable:
with open('out/cache/' +hashed_url, 'rb') as pickle_file:
content = pickle.load(pickle_file)
Aucune des deux méthodes ne prend en charge le chargement d'un cornichon à partir d'un nom de fichier.