确实,如前所述,通常最好遵循PEP 8的建议,并在顶部进行导入。虽然有一些例外。理解它们的关键在于您在第二段中嵌入的问题:“导入在哪个阶段发生?”
导入实际上是一个可执行语句。导入模块时,模块中的所有可执行语句都会运行。“
def”也是可执行的语句;它的执行将使定义的名称与(已编译的)代码相关联。因此,如果您有:
def f(): import something return None
在您导入的模块中,(已编译的)import和return语句此时与名称“ f”相关联。当您 运行 f()时,导入语句将运行。
如果您推迟导入“非常大”或“繁重”的东西,然后再也不运行该函数(在本例中为f),则导入永远不会发生。这样可以节省时间(以及一些空间)。当然,一旦您实际调用f(),导入就会发生(如果Python使用缓存的结果已经完成了导入,但是仍然需要检查),那么您将失去时间优势。
因此,根据经验,在完成大量分析后发现“导入所有内容”会浪费90%的运行时间,而在进行大量分析后才发现,导入“巨大的东西”会浪费大量时间其中的10%。



