出现EOFError: Ran out of input的解决办法

 具体出现错误如下:

 File "D:\python\CAIL2022-main\sjjc\LEVEN-main\Downstreams\LJP\LJP-Experiment\tools\train_tool.py", line 92, in train
    for step, data in enumerate(dataset):
  File "C:\Users\cong\anaconda3\envs\torch\lib\site-packages\torch\utils\data\dataloader.py", line 445, in __iter__
    return self._get_iterator()
  File "C:\Users\cong\anaconda3\envs\torch\lib\site-packages\torch\utils\data\dataloader.py", line 391, in _get_iterator
    return _MultiProcessingDataLoaderIter(self)
  File "C:\Users\cong\anaconda3\envs\torch\lib\site-packages\torch\utils\data\dataloader.py", line 1078, in __init__
    w.start()
  File "C:\Users\cong\anaconda3\envs\torch\lib\multiprocessing\process.py", line 112, in start
    self._popen = self._Popen(self)
  File "C:\Users\cong\anaconda3\envs\torch\lib\multiprocessing\context.py", line 223, in _Popen
    return _default_context.get_context().Process._Popen(process_obj)
  File "C:\Users\cong\anaconda3\envs\torch\lib\multiprocessing\context.py", line 322, in _Popen
    return Popen(process_obj)
  File "C:\Users\cong\anaconda3\envs\torch\lib\multiprocessing\popen_spawn_win32.py", line 89, in __init__
    reduction.dump(process_obj, to_child)
  File "C:\Users\cong\anaconda3\envs\torch\lib\multiprocessing\reduction.py", line 60, in dump
    ForkingPickler(file, protocol).dump(obj)
AttributeError: Can't pickle local object 'init_formatter.<locals>.train_collate_fn'
Traceback (most recent call last):
  File "<string>", line 1, in <module>
  File "C:\Users\cong\anaconda3\envs\torch\lib\multiprocessing\spawn.py", line 105, in spawn_main
    exitcode = _main(fd)
  File "C:\Users\cong\anaconda3\envs\torch\lib\multiprocessing\spawn.py", line 115, in _main
    self = reduction.pickle.load(from_parent)
EOFError: Ran out of input

原因是这个语句运行出错:

for step, data in enumerate(dataset):

打印datasets如下:

<torch.utils.data.dataloader.DataLoader object at 0x0000013B0F1CE3C8>

 经查,百度等发现需要在pytorch的torch.utils.data.DataLoader中,把参数num_workers(表示进程个数)改为0即可。

在dataloader.py文件第244行修改num_workers = 0

 问题解决

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值