当使用import导入Python模块的时候,默认调用的是__import__()
函数。直接使用该函数的情况很少见,一般用于动态加载模块。
__import__(name, globals, locals, fromlist, level)
只有name
是必选参数,其他都是可选参数,一般情况下直接使用name
参数即可。
fromlist
指明需要导入的子模块名,level指定导入方式(相对导入或者绝对导入, 默认两者都支持)。
当模块名为package.module
时,而且fromlist
参数为空时,函数返回顶层的模块,也就是package模块。如果fromlist=[module]
,则返回module
。
所以,下面语句返回的结果是一样的:
spam = __import__('spam', globals(), locals(), [], -1)
spam = __import__('spam.ham', globals(), locals(), [], -1)
而下面指定了fromlist
,就可以获取到子模块。
_temp = __import__('spam.ham', globals(), locals(), ['eggs', 'sausage'], -1)
eggs = _temp.eggs
saus = _temp.sausage
如果像直接通过名字导入模块,也可以使用importlib
模块的import_module
函数。
可以使用__import__
函数实现模块的延迟导入:
class LazyImport:
def __init__(self, module_name):
self.module_name = module_name
self.module = None
def __getattr__(self, name):
if self.module is None:
self.module = __import__(self.module_name)
return getattr(self.module, name)
string = LazyImport("string")
print string.lowercase
Python中的
__import__()
函数用来动态的加载包文件, 其中__import__()
有个fromlist
的参数选项, 对于动态加载模块来说, 非常重要
Python 中的 import 大概有以下几种用法
pkg.mod.func()
pkg.mod.func()
mod.func()
mod.func()
func()
func()
第一种和第二种情况下, 当使用__import__
导入模块时, 得到的对象是完全一样的. 默认情况下, __import__
只能导入最左侧的包文件, 即以下两种写法, 导入的对象都是一样的
pkg2 = __import__(pkg)
调用方法: pkg2.mod.func()
pkg3 = __import__(pkg.mod)
调用方法: pkg3.mod.func()
第三种情况下, 当使用__import__
导入模块时, 与import mod
的导入效果是一样的
__import__(mod)
调用方法: mod2.func1(); mod2.func2()
第四种情况下, 当使用__import__
导入模块时的用法
pkg4 = __import__(pkg, fromlist=[mod1, mod2])
调用方法:
pkg4.mod1.func1()
pkg4.mod2.func2()
第五种情况下, 不支持使用__import__
直接导入包内模块中的函数, 默认情况下, 即使你是如下的写法
pkg5 = __import__(pkg.mod)
效果依然是只导入pkg
包而已, pkg.mod
这个模块并没有被导入
pkg5 = __import__(pkg.mod, fromlist=[mod])
如果是加入了 fromlist
关键字的话, 那么该 pkg5 为 mod 模块对象
总结来说就是当 __import__(A.B)
时, 当 fromlist 为空, 则导入的对象时 A, 如果 fromlist 不为空, 导入的对象就是 B
第六种情况下, 当使用__import__
导入模块时, 与from mod import func
的效果是一样的, 不需要使用fromlist参数支持就可以导入全部函数
mod3 = __import__(mod)
调用方法: mod3.func()
pkg5 = __import__('mod2', fromlist=['func2', 'func3'])
这种写法非常啰嗦, 上面的写法已经可以导入全部函数了, 不需要再使用 fromlist 单独指定