vscode中python自定义包的模块如何导入其子包模块
问题描述
如图所示,对于python,有一个自定义包parent,它里面还有一个子包child,当你在parent.module1中import child.module2时,vscode会给你报错,说找不到这个包。
当你单独运行module1.py的时候,可以正常运行,但是当你在parent包外层的main.py中import parent.module1时,就会报错。

详细说明
目录结构为:
main.pyparent__init__.pymodule1.pychild__init__.pymodule2.py
其中:
main.py
1 | # main.py |
parent.__init__.py
1 | # parent.__init__.py |
child.__init__.py
1 | # child.__init__.py |
module1.py
1 | # module1.py |
module2.py
1 | # module2.py |
分析原因
当你单独运行module1.py的时候,可以正常运行,并输出:
1 | 导入了child包 |
这是因为vscode此时将module1.py作为相对路径的起点,从而找到了child.module2的位置。
但是当你在parent包外层的main.py中import parent.module1时,就会报错。
这是因为vscode此时将main.py作为相对路径的起点,对于main.py来说,它所在目录下是没有child包的,只有parent包,所以找不到,报错。
解决方案
在parent.__init__.py中添加三行代码,添加完之后如下所示:
1 | # parent.__init__.py |
python找包会在当前路径和sys.path中去查找,所以可以在导入parent包的时候,将它的路径加入sys.path当中,这样就可以找到parent包的子包了。
同时,因为是在__init__.py中加的,包内文件就不必每次都将粘贴一次这部分代码。
其中,os.path.realpath(__file__)获取本文件即parent.__init__.py的真实路径,os.path.dirname()将完整路径中的目录名提取出来,去掉其中的文件名。
添加后main.py运行结果:
1 | 导入了parent包 |
vscode中python自定义包的模块如何导入其子包模块
https://yxchangingself.xyz/posts/python-the-module-of-parentpkg-import-the-module-of-childpkg/