python的import机制(解决pycharm中遇到的自己的模块找不到,红波浪线问题)

本文深入解析Python中的模块和包的概念,探讨import语句的工作原理,包括路径搜索机制及如何解决PyCharm环境下模块导入失败的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言

我的个人网站:https://www.gentlecp.com

本篇博客主要是介绍关于python中模块导入的机制,以及常用ide——pycharm中容易遇到的模块导入失败的问题。可能包含的不会特别全面,如果你遇到不一样的情况也是import的错误,欢迎留言给我,我会找到解决方案并丰富到本博客当中。
python版本:3.6.4
pycharm版本:2018.2.4

一、模块与包

既然要说import,起码得先知道我们都要import什么。这里给出模块与包的定义:

  • 模块(module)
    用来从逻辑(实现一个功能)上组织Python代码(变量、函数、类),本质就是*.py文件。文件是物理上组织方式"module_name.py",模块是逻辑上组织方式"module_name"。

  • 包(package)
    定义了一个由模块和子包组成的Python应用程序执行环境,本质就是一个有层次的文件目录结构(python2要求必须带有一个__init__.py文件)。

例如:

import os # 导入os模块
import django # 导入django包
from django.db import models # 从django.db包中导入models模块

二、import本质

import 说白了就是找东西(模块和包),官方一点的说法叫路径搜索。既然要找东西,那么首先就有个问题,上哪找?
我们在写简单的python的程序时经常要用到os这个模块,这是python自带的。它的路径是你python的安装路径中的Lib目录。例如我的:

E:\idle\Lib\os.py # 我python的目录名称是idle

这个路径被存储在sys.path(列表类型)当中,可以通过以下命令查看得到:
在这里插入图片描述所以我们想要我们的包或模块可以被找到,只需要将它的根目录添加到sys.path中。
举个例子:
现在E盘路径是不在sys.path中的,我在E盘创建一个 A.py文件作为我的模块,里面只有一个函数打印hello这句话。
在这里插入图片描述
现在我在控制台尝试导入该模块,结果如下:
在这里插入图片描述
可以看到是找不到的,下面我在sys.path中添加该路径,再看一次效果:
在这里插入图片描述
可以看到这时候导入A就有效了,因为A模块的根目录被我添加到了sys.path中,python就可以找到A了。
不过这种方法只有在项目执行之时有效,因为是临时给sys.path添加路径,只存储在内存中,一旦重新打开一个控制台就失效了,需要再次添加路径。
在这里插入图片描述
当我们再打开E盘时发现该目录下多了个__pycache__文件夹,顾名思义就是python文件的缓存,打开文件夹会发现有一个A.cpython-36.pyc
在这里插入图片描述

关于该文件夹以及文件的解释可以看看这篇博客已经讲的很清楚了:
转:运行Python脚本时生成的__pycache__文件夹

三、pycharm中模块找不到的问题

在E盘用pycharm创建一个新的项目,查看它的sys.path得到结果如下。
在这里插入图片描述
可以看到pycharm默认添加了两个路径
这是因为pycharm默认设置的添加两个路径到PYTHONPATH,打开settings->Python Console,可以看到如下图:
在这里插入图片描述
Add content roots to PYTHONPATH
先看看官方对于content root 的解释:
在这里插入图片描述
大致意思就是说,content root 就是你当前工作项目的路径,每个项目至少有一个content root,其实就是你创建的项目所在路径。譬如我在E盘创建一个叫Fly的项目,那么它默认的content root 就是 E:\Fly,并且身为content root的文件夹显示是一个灰色文件夹的样式。
其实本质上相当于pycharm帮你执行了

sys.path.append('E:\\Fly') # 根据你项目的路径而改变

这样就可以在你的sys.path中发现多了一个你项目的路径,既然有了这个路径,那么该路径下的文件夹自然可以找到。

Add source roots to PYTHONPATH
在这里插入图片描述
source roots 包含了实际的源文件和所有资源,它会是pycharm用于import模块和包的第一个路径。所以我们看到的第一个E:\test就是source root。

创建项目结构目录文件如下:
在这里插入图片描述

先执行 ooo.py ,可以看到打印的sys.path如下:
在这里插入图片描述
再执行 xxx.py,可以看到打印的sys.path如下:
在这里插入图片描述

这说明pycharm会将执行代码的目录添加到sys.path中。
因为整个项目Fly在sys.path中,我们就可以通过下面的方式让xxx导入ooo的模块:
在这里插入图片描述
在这里插入图片描述

注意这里sys.path打印了两遍,说明在导入模块的时候,模块里的代码也会被执行,避免执行的方法是通过给 ooo.py 添加

if __name__ == '__main__':  	#在这下面添加被导入时你不希望执行的代码

这句话会让只有当前文件是执行文件的时候才会运行下面的代码。
在这里插入图片描述
在这里插入图片描述
扯远了,那么有没有办法在执行xxx的时候不需要借助项目Fly的路径直接导入ooo模块呢?
那必须是有的。
方法(1) 右键ddd->Mark directory as -> Sources Root
在这里插入图片描述
让xxx直接导入ooo,运行结果一样
在这里插入图片描述
在这里插入图片描述

方法(2) 在xxx中添加如下代码:
在这里插入图片描述
这相当于在代码执行的时候将ddd的路径添加到sys.path中,这样就可以找到ooo模块了,但是这种方法有一点不好的地方就是在import ooo的时候ooo下面还是红色波浪线,因为代码未被执行前,该路径还未被添加到其中,所有pycharm就找不到,但是不影响代码的运行。
ps:除了不美观以外,在写import的时候没有代码提示= =

看到这里,你是不是以为pycharm这样mark的方式,和自动帮你添加路径的方式就很棒,很好,比那种手动敲代码的方式好多了呢?别着急,接着往下看。

退出pycharm,用控制台运行 xxx.py,发现结果如下:
在这里插入图片描述

发现程序找不到ooo了,将import ooo 改成 from ddd import ooo:
在这里插入图片描述

因为不在pycharm中运行项目,此时就不会将项目根目录自动添加到sys.path中。
所以,为了让你的代码更具有通用性,移植到别人的电脑上依旧能使用,个人建议不要依赖pycharm的这种模式,选择自己手动代码添加路径的方式会更好。

小结:因此如果发现你在pycharm中导入自己的模块出现红色波浪线,提示找不到模块,先用sys.path检查是否包含了你包或模块的根目录,如果没有,就自己手动用代码添加吧,记住要添加在你引用该包或模块之前哦!

<think>好的,用户问的是如何在PyCharm解决导入CNNLSTMModel时出现的红色波浪线问题。首先,我需要回忆一下之前学过的关于PyCharm导入错误的解决方法。根据提供的引用,问题通常与Pythonimport机制有关,或者PyCharm的配置问题。 首先,用户提到的CNNLSTMModel可能是一个自定义模块。我需要考虑几个可能的原因。第一个可能是模块所在的目录没有被正确识别为源根目录。根据引用[3],在PyCharm中设置源根目录(Source Root)可以解决这个问题。用户需要检查项目结构设置,确认包含CNNLSTMModel的文件夹是否被标记为Source Folder。 第二个可能性是模块的路径没有添加到系统路径中。Python在导入模块时会搜索sys.path中的路径,如果模块不在这些路径里,就会不到。这时候可以手动添加路径,或者在代码中使用sys.path.append,但这种方法可能不够优雅,更推荐正确配置项目结构。 第三个可能是PyCharm的缓存问题。有时候缓存没有更新会导致误错误,这时候清除缓存并重启IDE可能会有帮助,如引用[4]提到的检查设置中的Inspections,可能涉及代码检查配置。 另外,用户的项目中可能存在同名的文件夹或模块,导致相对导入混淆,如引用[3]中的例子,两个文件夹有同名文件,导致相对导入失败。需要检查是否有命名冲突的情况,并调整目录结构或导入语句。 还有可能需要检查Python解释器是否正确配置,确保使用的解释器环境中有所有必要的依赖,并且项目结构正确。如果解释器环境错误,比如虚拟环境没有激活,或者缺少包,也会导致导入问题。 总结起来,解决步骤可能是: 1. 将模块所在目录设为源根目录。 2. 检查项目结构,避免同名冲突。 3. 确保解释器配置正确。 4. 清除缓存并重启PyCharm。 5. 检查导入语句是否正确,使用绝对导入或相对导入适当的方式。 还需要考虑用户是否在包内使用了__init__.py文件,如果没有的话,Python不会将目录识别为包,可能导致导入失败。此外,如果CNNLSTMModel属于某个子包,导入时需要完整的路径,比如from mypackage.models import CNNLSTMModel。 最后,可能需要指导用户如何具体操作PyCharm的设置,比如在项目结构中右键目录标记为Sources,或者调整代码样式检查中的相关设置,减少误。</think>### 解决PyCharm中导入CNNLSTMModel红色波浪线的方法 #### 1. 确认模块路径与项目结构 - **标记源根目录**:右键单击包含`CNNLSTMModel`的文件夹 → 选择`Mark Directory as` → `Sources Root`,使PyCharm将其识别为代码目录[^3]。 - **检查项目结构**:通过`File` → `Settings` → `Project: <项目名>` → `Project Structure`,确保模块所在路径已正确添加为源目录。 #### 2. 处理Python解释器配置 - **验证解释器环境**:在`Settings` → `Python Interpreter`中确认当前使用的解释器包含项目所需依赖。 - **重建虚拟环境**(可选):如果环境损坏,可删除`venv`文件夹后重新配置。 #### 3. 解决命名冲突与导入语法 - **避免同名文件/目录**:检查项目中是否有与`CNNLSTMModel`同名的文件或目录,修改命名或调整导入路径。 - **使用绝对导入**:例如,若模块路径为`src/models/CNNLSTMModel.py`,则导入语句应为: ```python from src.models import CNNLSTMModel # 或 from src.models.CNNLSTMModel import CNNLSTMModel ``` #### 4. 清理缓存与重启IDE - **清除缓存**:执行`File` → `Invalidate Caches` → `Invalidate and Restart`,解决因缓存导致的误[^4]。 #### 5. 调整代码检查规则 - **临时忽略检查**:在`Settings` → `Editor` → `Inspections` → `Python` → `Unresolved references`中降低检查等级(不推荐长期使用)。 --- ###
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值