当一个模块(如a.py)需要导入同一包内另一模块(如b.py)时,必须使用相对导入语法(如from .b import b),而非直接from b import b,否则会因模块搜索路径问题导致modulenotfounderror。
在Python包结构中,模块间的导入行为严格依赖于包上下文和导入方式
。你当前的目录结构符合标准Python包规范(dir/含__init__.py),但A.py中写的是from B import B——这是一种顶层绝对导入,Python会尝试在sys.path中查找名为B的顶级模块,而不会自动在当前包(dir)内搜索,因此报错ModuleNotFoundError: No module named 'B'。
✅ 正确做法是:在A.py中使用显式相对导入:
# dir/A.py
from .B import B # ✅ 相对导入:. 表示当前包(即 dir)
class A:
def __init__(self):
self.b = B() # 示例使用⚠️ 注意事项:
? 验证示例(终端命令):
立即学习“Python免费学习笔记(深入)”;
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('SUCCESS: A imported with B dependency resolved')" > parent_dir/C.py
cd parent_dir
python C.py # 输出 SUCCESS...? 补充建议:
总之,解决此类依赖的核心在于理解Python的模块解析机制:包内模块应优先使用相对导入定位同级依赖,外部调用方则使用绝对导入访问包接口。