原因:VScode默认的模块查找路径只包含当前工作目录,不会包括根目录和系统环境变量中的内容。可以在代码中添加如下命令来打印出结果,
import os
print("当前工作目录:", os.getcwd())
print("主程序所在目录:", os.path.dirname(os.path.abspath(__file__)))
print("编辑器检索路径:", os.environ.get('PYTHONPATH'))
工作目录一般为你所正在执行的程序的位置相同
主程序所在目录一般与工作目录相同
编辑器检索路径对于Vcode来说一般只限于主程序所在目录或为空
解决方案:可以通过修改配置文件,添加当前工作目录与系统环境变量PYTHONPATH中所写目录。在VScode中按快捷键:ctrl+shift+p,弹出查找框,输入:Open User Settings(JSON),点击后弹出settings.json文件,修改部分代码如下所示,如果没有则手动添加该代码。其中workspaceFolder就表示当前工作目录,PYTHONPATH就表示系统环境变量中所写入的目录。
"terminal.integrated.env.osx": {
"PYTHONPATH": "${workspaceFolder}:${env:PYTHONPATH}"
},
"terminal.integrated.env.linux": {
"PYTHONPATH": "${workspaceFolder}:${env:PYTHONPATH}"
},
"terminal.integrated.env.windows": {
"PYTHONPATH": "${workspaceFolder};${env:PYTHONPATH}"
}
如有报错请注意是否漏写“逗号”分隔符,即“,”。
修改完之后保存:ctrl+s,最后还需重载VScode窗口才可生效,同样通过快捷键:ctrl+shift+p,输入Reload Window后, 窗口重启。
注意:以上只适应于直接import根目录下的模块,如果是import子文件夹中模块,还需另外处理,这里举个栗子。
假设我打开的文件夹是A,附带子文件夹B和C,子文件夹B和C中分别要附带了文件main.py和plotting.py,如下图所示:
A/
├── B/
│ ├── main.py
├── C/
│ ├── plotting.py
当在主程序main.py中导入plotting.py中的模块时,以上所述操作是必要步骤,因为它保证了A文件夹被添加到了编辑器的检索目录中,其次通过以下代码来导入所需模块:
from C.plotting import XXX
这是因为plotting.py位于的根目录A的子文件夹C中,如果plotting.py位于根目录A所在文件夹中,则使用以下代码导入所需模块:
from plotting import XXX