在python3中使用importlib进行动态导入时出错

Uma*_*pta 5 import python-import dynamic-import python-3.x python-importlib

我一直在尝试importlib与python3(3.6)一起使用。

目录结构

main.py

#Note: I will only modify line 4 that uses importlib
import importlib
if __name__ == '__main__':
    print("In main.py")
    hello = importlib.import_module('hello', package='./')
    print("Loaded hello.py")
    hello.hello()
Run Code Online (Sandbox Code Playgroud)

你好

def hello():
    print('Hello world')
Run Code Online (Sandbox Code Playgroud)

文件夹/hello.py

def hello():
    print('Hello world in folder')
Run Code Online (Sandbox Code Playgroud)

观察结果

如果我做

hello = importlib.import_module('hello', package='./') 要么

hello = importlib.import_module('hello')

它从根文件夹导入hello.py并进行打印hello world

如果我做

hello = importlib.import_module('folder.hello')

它从根文件夹导入folder / hello.py并打印hello world in folder

但是如果我这样做

hello = importlib.import_module('hello', package='folder') 要么

hello = importlib.import_module('hello', package='./folder')

它给出了错误

Traceback (most recent call last):
  File "main.py", line 4, in <module>
    hello = importlib.import_module('hello', package='./folder')
  File "/usr/lib/python3.6/importlib/__init__.py", line 126, in import_module
    return _bootstrap._gcd_import(name[level:], package, level)
  File "<frozen importlib._bootstrap>", line 994, in _gcd_import
  File "<frozen importlib._bootstrap>", line 971, in _find_and_load
  File "<frozen importlib._bootstrap>", line 953, in _find_and_load_unlocked
ModuleNotFoundError: No module named 'hello'
Run Code Online (Sandbox Code Playgroud)

问题

我不确定这是怎么回事。我很确定我对python模块和软件包的理解有问题。有人可以解释为什么这是预期的行为吗?

Mah*_*esh 5

如果第一个参数(要导入的模块)是绝对模块引用(没有前导.),则第二个参数将被完全忽略。

要导入a相对于另一个模块的模块b,您必须使用

a = importlib.import_module('.a', package='b')
Run Code Online (Sandbox Code Playgroud)

在你的情况下,这应该工作

hello = importlib.import_module('.hello', package='folder')
Run Code Online (Sandbox Code Playgroud)

根据经验,import package如果要package用作第二个参数,应该可以使用。

from package import module
Run Code Online (Sandbox Code Playgroud)

然后变成

importlib.import_module(module, package)
Run Code Online (Sandbox Code Playgroud)

  • @UmangGupta,这是因为`sin` 是数学模块中的一个函数,它本身不是一个模块。你需要做`数学。= importlib.import_module('math')` 然后 `math.sin` 将工作。名称是 `import_module` 而不是 `import_function` (2认同)