我应该同时导入模块和子模块

路西法

我使用的logging库在Python 3。我想使用logging.handlers.RotatingFileHandlerlogging.Formatterlogging.getLogger在我的代码。

我观察到的是,以下操作(忽略函数的参数)均无任何错误:

import logging.handlers
log_formatter = logging.Formatter()
log_handler = logging.handlers.RotatingFileHandler()
logger = logging.getLogger()

在这种情况下,我还应该logging单独导入吗?
另外,导入子模块是否总是从Python的父模块中导入所有引用?

阿巴内特

通常,导入模块会导入其所有父级,并且不会导入其任何子模块。如果您使用纯Python实现所有功能,并且不做任何时髦的事情,那么它就是这样工作的。

但是扩展模块的工作方式可能有所不同。(例如,如果import os您得到os.path。)

而且纯Python代码可以做一些有趣的事情-例如,您可以编写一个动态构建软件包的顶级模块来代替磁盘上的实际软件包布局,在这种情况下,用户必须首先使用import该顶层模块(并且可能或可能无法免费获得子模块)。

总是安全的,明确import你要直接使用的一切。这样做并没有真正的害处-额外的一行代码,使进口商可以花几纳秒的时间才能看到模块已经在字典中,什么也不做,仅此而已。

同时,对于人类读者和实际上不执行imports的IDE来说很清楚当您致电时logging.getLogger,我可以看到您这样做了import logger,所以我知道那logging是一个模块,而不是其他一些全局变量。

但是,如果您确实愿意,您可以学习每个特定程序包的工作方式并使用该知识。在实践中,朝这个方向前进很少会造成混淆。而且,即使是相反的情况,许多现实世界的代码也确实依赖import os给您os.path

在的特殊情况下logging,我相信文档中的教程和食谱中的所有示例都是明确的import logging,因此,如果您要问什么是最惯用的,可能就是这样。

本文收集自互联网,转载请注明来源。

如有侵权,请联系 [email protected] 删除。

编辑于
0

我来说两句

0 条评论
登录 后参与评论

相关文章