如图所示,应该推荐使用 importlib 的方式。
scrapy 的源码也正是使用的这种方式
附scrapy 源码中 scrapy/utils/misc.py 中引入源码的load_object 实现
def load_object(path):
"""Load an object given its absolute object path, and return it.
object can be a class, function, variable or an instance.
path ie: 'scrapy.downloadermiddlewares.redirect.RedirectMiddleware'
"""
try:
dot = path.rindex('.')
except ValueError:
raise ValueError("Error loading object '%s': not a full path" % path)
module, name = path[:dot], path[dot+1:]
mod = import_module(module)
try:
obj = getattr(mod, name)
except AttributeError:
raise NameError("Module '%s' doesn't define any object named '%s'" % (module, name))
return obj
本文探讨了Python中动态引入模块的两种方法:importlib和__import__,并建议使用importlib的方式,因为其更符合最佳实践。以Scrapy框架源码为例,展示了在scrapy/utils/misc.py文件中如何使用importlib的load_object实现动态加载源码。
676

被折叠的 条评论
为什么被折叠?



