为什么Python模块有时不导入它们的子模块?

2022-03-31 00:00:00 python python-import

问题描述

我今天注意到一些奇怪的事情,我想解释一下。我甚至不能100%确定如何将这句话作为一个问题来表达,所以谷歌是不可能的。由于某种奇怪的原因,日志记录模块无权访问模块logging.handpers。如果你不相信我,你自己试试:

>>> import logging
>>> logging.handlers
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AttributeError: 'module' object has no attribute 'handlers'
>>> import logging.handlers
>>> logging.handlers
<module 'logging.handlers' from '/usr/lib/python2.6/logging/handlers.pyc'>

有人能解释为什么会发生这种情况吗?


解决方案

在Python中,需要先导入模块才能访问。import logging仅导入日志记录模块。碰巧logging是一个包含子模块的包,但这些子模块仍然不会自动加载。因此,您需要显式导入logging.handlers,然后才能访问它。

如果您想知道为什么有时看起来不需要这些额外的导入:一些包在导入时会导入它们的部分或所有子模块--只需在它们的__init__.py文件中执行这些导入。在其他情况下,可能是您导入的其他内容也导入了logging.handlers。执行导入的是哪段代码并不重要;只要流程中的某个在您访问它之前导入了logging.handlers,它就会在那里。有时,看起来像包的模块实际上并不是包,比如osos.pathos不是一个包,它只是导入正确的其他模块(适用于您的平台)并将其命名为path,这样您就可以os.path访问它。

相关文章