
当从父目录导入子目录中的类时,若该类又依赖同目录下的其他模块,需使用相对导入(如 `from .b import b`)而非绝对导入,否则会触发 `modulenotfounderror`。
在 Python 的包结构中,模块间的导入行为严格依赖于执行上下文和导入语法类型。你遇到的问题本质是:A.py 中使用了 from B import B 这一绝对导入语句,但 Python 解释器在运行 C.py 时,并不会将 dir/ 目录视为顶层包路径,因此 B 不在 sys.path 中,也无法被解析为顶层模块——于是报错 No module named 'B'。
✅ 正确做法是将 A.py 中的导入改为显式相对导入:
# dir/A.py
from .B import B # ✅ 相对导入:表示“当前包(dir)下的 B.py”
class A:
def __init__(self):
self.b = B() # 示例用法同时确保以下前提成立:
- dir/ 下存在 __init__.py(可以为空),使其被识别为合法 Python 包;
- 导入操作(如 from dir.A import A)必须在包外执行(即 C.py 在 parent_dir/),且不能直接运行 dir/A.py(否则相对导入会失败);
- 不要通过 python dir/A.py 运行 A.py —— 相对导入仅在作为模块被导入时有效。
? 补充说明:
立即学习“Python免费学习笔记(深入)”;
- . 表示当前包(dir);
- .. 表示上一级包(本例中不适用);
- 绝对导入(如 from dir.B import B)虽可在 C.py 中使用,但不应写在 A.py 内部,因为 A.py 无法预知其被调用时的顶层包名,硬编码 dir 会破坏可移植性。
? 验证示例(终端执行):
mkdir -p parent_dir/dir
touch parent_dir/dir/__init__.py
echo "class B: pass" > parent_dir/dir/B.py
echo "from .B import B\nclass A: pass" > parent_dir/dir/A.py
echo "from dir.A import A\nprint('Import successful:', A())" > parent_dir/C.py
cd parent_dir
python C.py # 输出:Import successful: <__main__.A object at 0x...>⚠️ 注意事项:
- 若使用 IDE(如 PyCharm、VS Code),请确认工作目录为 parent_dir,并启用 “Add content root to PYTHONPATH” 类似选项;
- 使用 if __name__ == '__main__': 测试 A.py 时,应改用 python -m dir.A 启动(此时 dir 被视为包),否则相对导入仍会失败;
- 避免混合使用绝对与相对导入逻辑,统一采用相对导入可提升包内模块的内聚性与可维护性。
总结:解决此类依赖问题的核心在于理解 Python 的模块解析机制——包内模块应优先使用相对导入声明同级依赖,而包外使用者则用绝对导入访问入口模块。这是构建健壮、可复用 Python 包的基础规范。










