从模块动态导入 class

Import class from module dynamically

我将 class 称为 'my_class' 放置在 'my_module' 中。我需要导入这个 class。我试着这样做:

import importlib
result = importlib.import_module('my_module.my_class')

但上面写着:

ImportError: No module named 'my_module.my_class'; 'my_module' is not a package

所以。如我所见,它仅适用于模块,但无法处理 classes。如何从模块导入 class?

预期 my_module 是一个包含名为 'my_class' 的模块的包。如果您需要导入一个 class,或者一般动态的属性,只需在导入模块后使用 getattr

cls = getattr(import_module('my_module'), 'my_class')

此外,是的,它只适用于模块。记住 importlib.import_module is a wrapper of the internal importlib.__import__ 函数。它不提供与完整 import 语句相同数量的功能,后者与 from 一起对导入的模块执行属性 look-up。

import importlib
import logging

logger = logging.getLogger(__name__)


def factory(module_class_string, super_cls: type = None, **kwargs):
    """
    :param module_class_string: full name of the class to create an object of
    :param super_cls: expected super class for validity, None if bypass
    :param kwargs: parameters to pass
    :return:
    """
    module_name, class_name = module_class_string.rsplit(".", 1)
    module = importlib.import_module(module_name)
    assert hasattr(module, class_name), "class {} is not in {}".format(class_name, module_name)
    logger.debug('reading class {} from module {}'.format(class_name, module_name))
    cls = getattr(module, class_name)
    if super_cls is not None:
        assert issubclass(cls, super_cls), "class {} should inherit from {}".format(class_name, super_cls.__name__)
    logger.debug('initialising {} with params {}'.format(class_name, kwargs))
    obj = cls(**kwargs)
    return obj