EOFError: marshal data too short 已解决

EOFError: marshal data too short 已解决

明明什么也没改,跑程序的时候就突然报这个错,import numpy都不行了…找了好久,知道要删掉__pycache__但是不知道删哪里的,其实很简单,找到最后的报错点,顺藤摸瓜就可以!

报错内容

  File "<frozen importlib._bootstrap>", line 955, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 665, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 674, in exec_module
  File "<frozen importlib._bootstrap_external>", line 779, in get_code
  File "<frozen importlib._bootstrap_external>", line 487, in _compile_bytecode
EOFError: marshal data too short
(object_detection) [root@a28d572945c1 vggish]# python vggish_extract_features.py 
Traceback (most recent call last):
  File "vggish_extract_features.py", line 51, in <module>
    import numpy as np
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/numpy/__init__.py", line 187, in <module>
    from .testing import Tester
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/numpy/testing/__init__.py", line 10, in <module>
    from unittest import TestCase
  File "/root/miniconda2/envs/object_detection/lib/python3.6/unittest/__init__.py", line 59, in <module>
    from .case import (TestCase, FunctionTestCase, SkipTest, skip, skipIf,
  File "/root/miniconda2/envs/object_detection/lib/python3.6/unittest/case.py", line 6, in <module>
    import logging
  File "<frozen importlib._bootstrap>", line 971, in _find_and_load
  File "<frozen importlib._bootstrap>", line 955, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 665, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 674, in exec_module
  File "<frozen importlib._bootstrap_external>", line 779, in get_code
  File "<frozen importlib._bootstrap_external>", line 487, in _compile_bytecode
EOFError: marshal data too short

解决方法

从报错可以看出最后是import logging出错了,所以删掉/root/miniconda2/envs/object_detection/lib/python3.6/logging
这个目录下的__pycache__目录

cd /root/miniconda2/envs/object_detection/lib/python3.6/logging
rm -rf __pycache__

注意object_detection是我的conda环境的名字
完美解决~

2022.04.26更新

没想到这么快又碰到了一回这个错误,而且更加错综复杂了

>>> from sklearn import metrics
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/sklearn/__init__.py", line 82, in <module>
    from .base import clone
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/sklearn/base.py", line 17, in <module>
    from .utils import _IS_32BIT
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/sklearn/utils/__init__.py", line 23, in <module>
    from .class_weight import compute_class_weight, compute_sample_weight
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/sklearn/utils/class_weight.py", line 7, in <module>
    from .validation import _deprecate_positional_args
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/sklearn/utils/validation.py", line 22, in <module>
    import joblib
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/joblib/__init__.py", line 120, in <module>
    from .parallel import Parallel
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/joblib/parallel.py", line 26, in <module>
    from ._parallel_backends import (FallbackToBackend, MultiprocessingBackend,
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/joblib/_parallel_backends.py", line 17, in <module>
    from .pool import MemmappingPool
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/joblib/pool.py", line 31, in <module>
    from ._memmapping_reducer import get_memmapping_reducers
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/joblib/_memmapping_reducer.py", line 37, in <module>
    from .externals.loky.backend import resource_tracker
  File "/root/miniconda2/envs/object_detection/lib/python3.6/site-packages/joblib/externals/loky/__init__.py", line 12, in <module>
    from .backend.reduction import set_loky_pickler
  File "<frozen importlib._bootstrap>", line 971, in _find_and_load
  File "<frozen importlib._bootstrap>", line 955, in _find_and_load_unlocked
  File "<frozen importlib._bootstrap>", line 665, in _load_unlocked
  File "<frozen importlib._bootstrap_external>", line 674, in exec_module
  File "<frozen importlib._bootstrap_external>", line 779, in get_code
  File "<frozen importlib._bootstrap_external>", line 487, in _compile_bytecode
EOFError: marshal data too short

找了半天不知道.backend。reduction这种怎么弄,
聪明的我这么干的

ctrl+click先跳到报错的那个函数
在这里插入图片描述
看到最上面一行的目录关系了么,把所有的__pycache__目录都删掉就可以了!

[root@a28d572945c1 object_detection] cd lib/python3.6/site-packages/joblib
[root@a28d572945c1 joblib] rm -rf __pycache__/
[root@a28d572945c1 joblib] cd externals/
[root@a28d572945c1 externals] rm -rf __pycache__/
[root@a28d572945c1 externals] cd loky/
[root@a28d572945c1 loky] rm -rf __pycache__/
[root@a28d572945c1 loky] cd backend/
[root@a28d572945c1 backend] rm -rf __pycache__/

参考链接

https://github.com/PaddlePaddle/PaddleSeg/issues/1867
https://groups.google.com/g/comp.lang.python/c/easB1mE3rJY?pli=1

  • 4
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
当使用pickle模块序列化或反序列化数据时,如果出现EOFError: ran out of input错误,可能是以下几种情况导致的: 1. 文件内容为空或者文件不存在。 如果你使用pickle.load()读取文件序列化的数据,但是你的文件不存在或者为空,那么就会出现EOFError: ran out of input错误。 2. 文件内容被修改。 如果你在序列化数据后修改了文件内容,再次读取时,就会出现EOFError: ran out of input错误。 3. 序列化数据格式错误。 如果你序列化的数据格式不正确,比如pickle.dump()后面跟了一个非序列化对象,那么在读取时就会出现EOFError: ran out of input错误。 解决办法: 1. 检查文件是否存在或者为空。 在使用pickle.load()读取文件之前,需要检查文件是否存在或者为空。例如: ``` import os import pickle filename = "data.pkl" if os.path.exists(filename) and os.path.getsize(filename) > 0: with open(filename, "rb") as f: data = pickle.load(f) else: data = None ``` 2. 不要修改序列化文件。 在序列化数据后,不要修改文件内容,否则在读取时会出现EOFError: ran out of input错误。 3. 检查序列化数据格式是否正确。 在序列化数据时,需要确保序列化的数据格式是正确的。例如: ``` import pickle data = {"name": "Tom", "age": 18} # 正确的序列化方式 with open("data.pkl", "wb") as f: pickle.dump(data, f) # 错误的序列化方式 with open("data.pkl", "wb") as f: pickle.dump("hello world", f) ``` 如果出现了EOFError: ran out of input错误,可以尝试使用try...except捕获异常,并输出错误信息以便于定位问题: ``` try: with open(filename, "rb") as f: data = pickle.load(f) except EOFError as e: print("读取文件{}时发生错误:{}".format(filename, e)) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值