
在Python中,当我们需要在不同的文件或目录中使用已定义的函数、类或变量时,就需要使用模块导入(import)机制。然而,当文件位于不同的目录层级时,直接导入可能会遇到ModuleNotFoundError错误。这通常是因为Python解释器未能正确识别目标目录为一个可导入的“包”。
考虑以下文件结构:
Parent/
├── app.py
└── test/
└── testFunc.py其中,testFunc.py 定义了两个函数:
# testFunc.py
def testRound(value):
return int(value + 0.5)
def isEligible(name, age):
if age >= 18:
return 'Hello ' + name + ', ' + 'you are eligible for driving'
else:
return 'Hello ' + name + ', ' + 'you are not eligible'而 app.py 尝试从 testFunc.py 导入这些函数:
立即学习“Python免费学习笔记(深入)”;
# app.py
from test.testFunc import *
print(isEligible('Shakya', 18))
print(testRound(4.5))在执行 app.py 时,很可能会遇到 ModuleNotFoundError: No module named 'test' 或类似错误。这是因为Python在查找 test 这个“模块”时,并没有将其视为一个包含其他模块的“包”。
Python通过在目录中放置一个名为 __init__.py 的空文件来识别一个目录为一个包(package)。这个文件告诉Python解释器,该目录应该被视为一个Python包,其中的模块可以被导入。
要解决上述导入问题,只需在 test 目录下创建一个空的 __init__.py 文件。
正确的目录结构应为:
Parent/
├── app.py
└── test/
├── __init__.py # 新增的空文件
└── testFunc.py__init__.py 文件可以是空的,也可以包含包的初始化代码(例如定义 __all__ 变量来控制 from package import * 的行为,或者执行一些初始化设置)。对于简单的模块导入,一个空文件就足够了。
在添加 __init__.py 文件后,testFunc.py 和 app.py 的内容保持不变。
testFunc.py:
# Parent/test/testFunc.py
def testRound(value):
return int(value + 0.5)
def isEligible(name, age):
if age >= 18:
return 'Hello ' + name + ', ' + 'you are eligible for driving'
else:
return 'Hello ' + name + ', ' + 'you are not eligible'app.py:
# Parent/app.py
from test.testFunc import *
print(isEligible('Shakya', 18))
print(testRound(4.5))现在,当你在 Parent 目录下执行 python app.py 时,程序将能够成功运行并输出:
Hello Shakya, you are eligible for driving 5
正确理解和使用 __init__.py 文件是构建结构化、可维护的Python项目的基础。通过将相关的模块组织成包,不仅可以避免 ModuleNotFoundError,还能提高代码的模块化程度和复用性。始终确保你的项目目录结构能够清晰地反映其包的层次,并遵循Python的模块导入规范。
以上就是Python模块导入:跨目录引用函数的最佳实践的详细内容,更多请关注php中文网其它相关文章!
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号