note: 最近在入门pytorch的torchaudio模块,学习一下语音的基础知识,之前下的pytoch的版本是1.9.0,在pytoch的官方文档中使用from torchaudio.utils import download_asset发现里面并没有download_asset这个方法,应该是torchaudio的版本太低了,所以将pytoch的版本升级到1.13.0 。其实本来应该我只用torchaudio模块是没有这个问题的,但是使用了一下torchvision这个模块就有了本文的这个报错信息,其实应该是import torchvision引起的。

简单分析一下原因,大概是版本不一致的原因,我的anaconda的虚拟环境python版本是3.7,typing这个文件里面并没有OrderedDict这个模块,但是pytoch的1.13.0版本的torchvision模块里面需要从typing中导入OrderedDict。也许python版本高一些可能不会存在这个问题??

查看报错的完整栈信息,这个文件”D:\Programming-language-program\Anaconda3\lib\site-packages\torchvision\models\maxvit.py” maxvit.py里面从typing中导入了OrderedDict,但是它并没有这个。

解决方法
我们可以安装typing_extensions(这是针对python3.8版本以下的使用方法),相当于是对typing的一个补丁文件,里面会增加一些typing里面没有的东西。安装代码如下:

pip install typing_extensions

然后修改上文提及的maxvit.py文件,不从typing中导入OrderedDict模块,而是从typing_extensions中导入,即可解决问题。

总结: python、pytorch是存在版本对应关系的,很容易出现版本不一致报错的问题,尤其是python版本变更,或者pytoch版本变更时,原来的代码可能会存在一定的问题。还是要多用anaconda开虚拟环境,我就是偷懒了,主要还是想利用之前安装好的各种库,不想重新下载。