Python中的本地导入语句

发布于 2021-01-29 18:40:50

我认为将import语句放在靠近使用它的片段的位置,可以通过使其依赖项更加清晰来提高可读性。Python会缓存吗?我应该在乎吗?这是一个坏主意吗?

def Process():
    import StringIO
    file_handle=StringIO.StringIO('hello world')
    #do more stuff

for i in xrange(10): Process()

还有一点理由:这是针对使用库中奥秘功能的方法的,但是当我将方法重构为另一个文件时,我没有意识到我会错过外部依赖项,直到遇到运行时错误。

关注者
0
被浏览
50
1 个回答
  • 面试哥
    面试哥 2021-01-29
    为面试而生,有面试问题,就找面试哥。

    其他答案似乎对import真正的工作方式略有困惑。

    这个说法:

    import foo
    

    大致等效于以下语句:

    foo = __import__('foo', globals(), locals(), [], -1)
    

    也就是说,它将在当前作用域中创建一个与所请求的模块同名的变量,并为其分配__import__()使用该模块名和大量默认参数的调用结果。

    __import__()函数从概念上将字符串('foo')转换为模块对象。模块被缓存在sys.modules,这是第一位__import__()的外观-
    如果sys.modules中有一个条目'foo',这就是__import__('foo')要回来,不管它是什么。它真的不在乎类型。您可以自己查看此操作。尝试运行以下代码:

    import sys
    sys.modules['boop'] = (1, 2, 3)
    import boop
    print boop
    

    暂时不考虑样式问题,在函数内使用import语句可以实现所需的功能。如果模块从未被导入过,它将被导入并缓存在sys.modules中。然后,它将模块分配给具有该名称的局部变量。它不会
    修改任何模块级别的状态。它可能 确实 会修改某些全局状态(向sys.modules添加新条目)。

    也就是说,我几乎从未import在函数内部使用过。如果导入模块会在您的程序中造成明显的减速(例如它在静态初始化中执行了很长的计算,或者它只是一个庞大的模块),而您的程序很少真正需要该模块来执行任何操作,那么只在内部导入就可以使用它的功能。(如果这很令人反感,Guido会跳入他的时间机器,并更改Python以阻止我们这样做。)但是,通常,我和Python一般社区将我们所有的import语句放在模块范围内的模块顶部。



知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看