其他答案似乎对
import真正的工作方式略有困惑。
这个说法:
import foo
大致等效于以下语句:
foo = __import__('foo', globals(), locals(), [], -1)也就是说,它将在当前作用域中创建一个与所请求的模块同名的变量,并为其分配
__import__()使用该模块名和大量默认参数的调用结果。
该
__import__()函数从概念上将字符串(
'foo')转换为模块对象。模块被缓存在
sys.modules,这是第一位
__import__()的外观-
如果sys.modules中有一个条目
'foo',这就是
__import__('foo')要回来,不管它是什么。它真的不在乎类型。您可以自己查看此操作。尝试运行以下代码:import syssys.modules['boop'] = (1, 2, 3)import boopprint boop
暂时不考虑样式问题,在函数内使用import语句可以实现所需的功能。如果模块从未被导入过,它将被导入并缓存在sys.modules中。然后,它将模块分配给具有该名称的局部变量。它不会
不 修改任何模块级别的状态。它可能 确实 会修改某些全局状态(向sys.modules添加新条目)。
也就是说,我几乎从未
import在函数内部使用过。如果导入模块会在您的程序中造成明显的减速(例如它在静态初始化中执行了很长的计算,或者它只是一个庞大的模块),而您的程序很少真正需要该模块来执行任何操作,那么只在内部导入就可以使用它的功能。(如果这很令人反感,Guido会跳入他的时间机器,并更改Python以阻止我们这样做。)但是,通常,我和Python一般社区将我们所有的import语句放在模块范围内的模块顶部。



