Why do I get “Pickle - EOFError: Ran out of input” reading an empty file?

前端 未结 7 2415
小鲜肉
小鲜肉 2020-11-28 05:55

I am getting an interesting error while trying to use Unpickler.load(), here is the source code:

open(target, \'a\').close()
scores = {};
with o         


        
相关标签:
7条回答
  • 2020-11-28 06:20

    You can catch that exception and return whatever you want from there.

    open(target, 'a').close()
    scores = {};
    try:
        with open(target, "rb") as file:
            unpickler = pickle.Unpickler(file);
            scores = unpickler.load();
            if not isinstance(scores, dict):
                scores = {};
    except EOFError:
        return {}
    
    0 讨论(0)
  • 2020-11-28 06:23

    Most of the answers here have dealt with how to mange EOFError exceptions, which is really handy if you're unsure about whether the pickled object is empty or not.

    However, if you're surprised that the pickle file is empty, it could be because you opened the filename through 'wb' or some other mode that could have over-written the file.

    for example:

    filename = 'cd.pkl'
    with open(filename, 'wb') as f:
        classification_dict = pickle.load(f)
    

    This will over-write the pickled file. You might have done this by mistake before using:

    ...
    open(filename, 'rb') as f:
    

    And then got the EOFError because the previous block of code over-wrote the cd.pkl file.

    When working in Jupyter, or in the console (Spyder) I usually write a wrapper over the reading/writing code, and call the wrapper subsequently. This avoids common read-write mistakes, and saves a bit of time if you're going to be reading the same file multiple times through your travails

    0 讨论(0)
  • 2020-11-28 06:36

    It is very likely that the pickled file is empty.

    It is surprisingly easy to overwrite a pickle file if you're copying and pasting code.

    For example the following writes a pickle file:

    pickle.dump(df,open('df.p','wb'))
    

    And if you copied this code to reopen it, but forgot to change 'wb' to 'rb' then you would overwrite the file:

    df=pickle.load(open('df.p','wb'))
    

    The correct syntax is

    df=pickle.load(open('df.p','rb'))
    
    0 讨论(0)
  • 2020-11-28 06:38

    As you see, that's actually a natural error ..

    A typical construct for reading from an Unpickler object would be like this ..

    try:
        data = unpickler.load()
    except EOFError:
        data = list()  # or whatever you want
    

    EOFError is simply raised, because it was reading an empty file, it just meant End of File ..

    0 讨论(0)
  • 2020-11-28 06:43

    I would check that the file is not empty first:

    import os
    
    scores = {} # scores is an empty dict already
    
    if os.path.getsize(target) > 0:      
        with open(target, "rb") as f:
            unpickler = pickle.Unpickler(f)
            # if file is not empty scores will be equal
            # to the value unpickled
            scores = unpickler.load()
    

    Also open(target, 'a').close() is doing nothing in your code and you don't need to use ;.

    0 讨论(0)
  • 2020-11-28 06:43

    Note that the mode of opening files is 'a' or some other have alphabet 'a' will also make error because of the overwritting.

    pointer = open('makeaafile.txt', 'ab+')
    tes = pickle.load(pointer, encoding='utf-8')
    
    0 讨论(0)
提交回复
热议问题