I am learning the program written by other programmer. So I would like to view the structure of the pickled item. Since I need to know the structure of pickled data, I am trying to load pickle in Ipython using Spyder... e.g.:
import pickle
data1 = {'a': [1, 2.0, 3, 4+6j],
'b': ('string', u'Unicode string'),
'c': None}
selfref_list = [1, 2, 3]
#selfref_list.append(selfref_list)
output = open('data.pkl', 'wb')
# Pickle dictionary using protocol 0.
pickle.dump(data1, output)
# Pickle the list using the highest protocol available.
pickle.dump(selfref_list, output, -1)
output.close()
I would like to know the structure of the .pkl file pickled here.
What to do when we don't know how many items are pickled...
Found an answer:
It's not clear what you mean by
structure
. If I run your code, I can then do:I can recover your successive writes with an equal number of reads. If I try to get more I get a
EOFError: Ran out of input
.What do you want to know? How any objects there are on the file? The structure of each object? The conversion between Python object and bytes on the file?