我有一些位于不同目录中的模块。只有当类是module
的子类时,如何才能在这些ParentClass
中实例化类?从本质上讲,我正在尝试下面这样的事情,并想知道如何实现child_class_name
from importlib.machinery import SourceFileLoader
from parent_class import ParentClass
instances = []
script_path1 = r'/some/different/directory/some_child.py'
script_path2 = r'/some/different/directory/another_child.py'
for script_path in [script_path1, script_path2]:
module = SourceFileLoader('module', script_path).load_module()
child_class_name = "If a class in this module is a subclass of ParentClass"
ChildClass = getattr(module, child_class_name)
instances.append(ChildClass())
答案 0 :(得分:2)
这应该适用于这个理解列表:
childclasses = [obj for obj in vars(module).values()
if isinstance(obj,type) and issubclass(obj,ParentClass)]
vars(module).values()
返回模块中的所有对象。
然后,您可以使用issubclass(obj,ParentClass)
过滤子类。
(isinstance
只会帮助过滤类对象。)
childclasses
是您可以直接实例化的类列表,而不使用getattr
:
for ChildClass in childclasses:
instances.append(ChildClass())
编辑:
要避免ParentClass
,您可以将列表转换为集合,如果存在则将其删除:
childclasses = set([obj for obj in vars(module).values()
if isinstance(obj,type) and issubclass(obj,ParentClass)])
if ParentClass in childclasses:
childclasses.remove(ParentClass)
或在理解中添加另一个测试:
childclasses = [obj for obj in vars(module).values()
if isinstance(obj,type) and
issubclass(obj,ParentClass)and
obj is not ParentClass ]