ImportError: cannot import name ‘OrderedDict‘ from ‘typing‘ (D:\Programming-language-program\Anacond
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开虚拟环境,我就是偷懒了,主要还是想利用之前安装好的各种库,不想重新下载。
来源地址:https://blog.csdn.net/weixin_46202290/article/details/127886019
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341