报错AttributeError: Attempted to set WANDB to False, but CfgNode is immutable

问题

今天在跑代码的时候,使用到了wandb记录训练数据。

我在23服务器上跑的好好的,但将环境迁移到80服务器上重新开始跑时,却遇到了如下报错

看这个报错信息是由于wandb没有apis这个属性,于是我定位到具体的报错代码

😯原来程序在import wandb时就抛出异常了。

解决方法

我尝试验证是报错的原因在于程序导入wandb不成功而导致报错

因此,我在终端打开python解释器,执行import wandb,果然出现了一模一样的报错信息

既然是wandb库的原因,一个很自然的想法便是对比27和80服务器上两个wandb库的版本号。

23服务器上wandb的版本号为0.15.11

80服务器上wandb的版本号为0.15.12

我抱着试试看的心态将80服务器上wandb的版本号更换为0.15.11,然后再次运行程序,成功!

bash 复制代码
pip install wandb==0.15.11

版本号不同的原因

事后,我思考了一下为什么会导致版本号不同。首先我利用27上导出的yml文件在80上创建环境,即用conda env create -f mdistiller.yml

而该yml文件中wandb的版本号是正确的0.15.11

但后来我在通过该yml文件安装pytorch时中断了,因此使用pip install单独安装了pytorch。

然而pytorch安装中断会导致在pytorch之后剩下的包没有安装。所以,我使用了代码库的requirements.txt对剩下的包进行安装。

结果我看了下requirement.txt中的wandb并没有指定版本号,这就导致了安装的wandb为0.15.12版本

至于为什么通过yml文件在安装pytorch时会中断,我想可能是因为我当初安装pytorch时使用了pip而不是conda安装

相关推荐
开源技术17 分钟前
如何将本地LLM模型与Ollama和Python集成
开发语言·python
weixin_4370446417 分钟前
Netbox批量添加设备——堆叠设备
linux·网络·python
我有医保我先冲19 分钟前
AI 时代 “任务完成“ 与 “专业能力“ 的区分:理论基础、行业影响与个人发展策略
人工智能·python·机器学习
测试开发Kevin1 小时前
小tip:换行符CRLF 和 LF 的区别以及二者在实际项目中的影响
java·开发语言·python
爱学习的阿磊1 小时前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python
阿狸OKay1 小时前
einops 库和 PyTorch 的 einsum 的语法
人工智能·pytorch·python
编码者卢布2 小时前
【Azure Storage Account】Azure Table Storage 跨区批量迁移方案
后端·python·flask
可触的未来,发芽的智生2 小时前
狂想:为AGI代称造字ta,《第三类智慧存在,神的赐名》
javascript·人工智能·python·神经网络·程序人生
吴维炜2 小时前
「Python算法」计费引擎系统SKILL.md
python·算法·agent·skill.md·vb coding
FansyMeng3 小时前
VSCode配置anaconda
vscode·python