
当一个模块(如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() # 示例使用⚠️ 注意事项:
- . 表示当前包(dir),.. 表示父包(此处不适用),不可省略;
- 相对导入只能在包内模块中使用,且必须通过包方式运行(即不能直接执行python dir/A.py);
- C.py中的导入(from dir.A import A)是合法的绝对导入,因为它位于包外部,且dir是可导入的包(有__init__.py);
? 验证示例(终端命令):
立即学习“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...? 补充建议:
- 若项目较大,推荐在dir/__init__.py中显式导出公共接口,例如添加from .A import A和from .B import B,之后可统一用from dir import A, B;
- 避免在模块中混用绝对与相对导入逻辑,保持风格一致;
- 使用python -m运行时需确保当前工作目录在parent_dir之上,且parent_dir在PYTHONPATH中(或通过-m以包形式启动)。
总之,解决此类依赖的核心在于理解Python的模块解析机制:包内模块应优先使用相对导入定位同级依赖,外部调用方则使用绝对导入访问包接口。










