为什么Python模块有时不导入它们的子模块?
问题描述
我今天注意到一些奇怪的事情,我想解释一下。我甚至不能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
,它就会在那里。有时,看起来像包的模块实际上并不是包,比如os
和os.path
。os
不是一个包,它只是导入正确的其他模块(适用于您的平台)并将其命名为path
,这样您就可以os.path
访问它。
相关文章