我的编程空间,编程开发者的网络收藏夹
学习永远不晚

ModuleNotFoundError: No module named ‘models‘ 的解决方法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

ModuleNotFoundError: No module named ‘models‘ 的解决方法

参考博客:
ModuleNotFoundError: No module named ‘models‘解决torch.load问题【天坑】

保存与加载

使用 torch.save(model, “my_model.pth”) 命令可以保存整个模型。
这个保存/加载过程使用最直观的语法,涉及的代码最少。
以这种方式保存模型将使用Python的 pickle 模块保存整个model。
但是,在进行torch.load(“my_model.pth”)时,加载目录与保存目录要相同,这里的目录不是"my_model.pth",而是项目中定义模型所涉及的目录。举个例子:

load-test工程中有model_1文件夹,model_1文件夹中有yolo.py模块。
在这里插入图片描述
yolo.py:

import torchclass MyNet(torch.nn.Module):    def __init__(self):        super(MyNet, self).__init__()  # 第一句话,调用父类的构造函数        self.conv1 = torch.nn.Conv2d(3, 32, 3, 1, 1)        self.relu1 = torch.nn.ReLU()        self.max_pooling1 = torch.nn.MaxPool2d(2, 1)        self.conv2 = torch.nn.Conv2d(32, 32, 3, 1, 1)        self.relu2 = torch.nn.ReLU()        self.max_pooling2 = torch.nn.MaxPool2d(2, 1)        self.dense1 = torch.nn.Linear(32 * 3 * 3, 128)        self.dense2 = torch.nn.Linear(128, 10)    def forward(self, x):        x = self.conv1(x)        x = self.relu1(x)        x = self.max_pooling1(x)        x = self.conv2(x)        x = self.relu2(x)        x = self.max_pooling2(x)        x = self.dense1(x)        x = self.dense2(x)        return x

在train.py中导入模型并保存整个模型:

from model_1.yolo import MyNetimport torchnet = MyNet()torch.save(net, './weights/net.pt')  # 保存

将net.pt保存在weights文件夹中。
然后在train.py中加载模型:

import torchmodel = torch.load('./weights/net.pt')

是成功的(也不需要 from model_1.yolo import MyNet )。

如果将model_1文件夹改为model_2文件夹,则出错。
在这里插入图片描述
出错的原因是导入模型时的目录与保存时的目录不一致。

解决方案

有时候需要将训练好的模型导入另一个工程中,但是该工程的文件夹与原文件夹相同且不方便更改,这时可以采取: 先加载模型,然后保存模型参数,再加载模型参数 的方法来正确加载模型。

先保持model_1文件夹不变。
train.py:

import torchmodel = torch.load('./weights/net.pt')torch.save(model.state_dict(), './weights/net_state_dict.pt')  # 保存

将model_1文件夹改为model_2文件夹。
train.py:

from model_2.yolo import MyNetimport torchmodel = MyNet()state_dict = torch.load('./weights/net_state_dict.pt')model.load_state_dict(state_dict)

加载成功。

来源地址:https://blog.csdn.net/tpz789/article/details/126847173

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

ModuleNotFoundError: No module named ‘models‘ 的解决方法

下载Word文档到电脑,方便收藏和打印~

下载Word文档

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录