给定完整路径,如何导入模块?
时间:2020-03-05 18:54:42 来源:igfitidea点击:
给定完整路径,如何加载Python模块?请注意,该文件可以在文件系统中的任何位置,因为它是一个配置选项。
解决方案
回答
我相信我们可以使用imp.find_module()
和imp.load_module()
加载指定的模块。我们需要从路径中拆分模块名称,即,如果我们想加载/ home / mypath / mymodule.py
,则需要执行以下操作:
imp.find_module('mymodule', '/home/mypath/')
...但这应该可以完成工作。
回答
对于Python 3.5+,请使用:
import importlib.util spec = importlib.util.spec_from_file_location("module.name", "/path/to/file.py") foo = importlib.util.module_from_spec(spec) spec.loader.exec_module(foo) foo.MyClass()
对于Python 3.3和3.4,请使用:
from importlib.machinery import SourceFileLoader foo = SourceFileLoader("module.name", "/path/to/file.py").load_module() foo.MyClass()
(尽管在Python 3.4中已弃用此功能。)
Python 2使用:
import imp foo = imp.load_source('module.name', '/path/to/file.py') foo.MyClass()
编译后的Python文件和DLL具有等效的便捷功能。
也可以看看。 http://bugs.python.org/issue21436.
回答
我们可以使用
load_source(module_name, path_to_file)
imp模块中的方法。
回答
在运行时导入软件包模块(Python配方)
http://code.activestate.com/recipes/223972/
################### ## # ## classloader.py # ## # ################### import sys, types def _get_mod(modulePath): try: aMod = sys.modules[modulePath] if not isinstance(aMod, types.ModuleType): raise KeyError except KeyError: # The last [''] is very important! aMod = __import__(modulePath, globals(), locals(), ['']) sys.modules[modulePath] = aMod return aMod def _get_func(fullFuncName): """Retrieve a function object from a full dotted-package name.""" # Parse out the path, module, and function lastDot = fullFuncName.rfind(u".") funcName = fullFuncName[lastDot + 1:] modPath = fullFuncName[:lastDot] aMod = _get_mod(modPath) aFunc = getattr(aMod, funcName) # Assert that the function is a *callable* attribute. assert callable(aFunc), u"%s is not callable." % fullFuncName # Return a reference to the function itself, # not the results of the function. return aFunc def _get_class(fullClassName, parentClass=None): """Load a module and retrieve a class (NOT an instance). If the parentClass is supplied, className must be of parentClass or a subclass of parentClass (or None is returned). """ aClass = _get_func(fullClassName) # Assert that the class is a subclass of parentClass. if parentClass is not None: if not issubclass(aClass, parentClass): raise TypeError(u"%s is not a subclass of %s" % (fullClassName, parentClass)) # Return a reference to the class itself, not an instantiated object. return aClass ###################### ## Usage ## ###################### class StorageManager: pass class StorageManagerMySQL(StorageManager): pass def storage_object(aFullClassName, allOptions={}): aStoreClass = _get_class(aFullClassName, StorageManager) return aStoreClass(allOptions)
回答
我们还可以执行类似的操作,并将配置文件所在的目录添加到Python加载路径中,然后进行常规导入,前提是我们事先知道文件名,在本例中为" config"。
凌乱,但有效。
configfile = '~/config.py' import os import sys sys.path.append(os.path.dirname(os.path.expanduser(configfile))) import config
回答
我们是指加载还是导入?
我们可以操纵sys.path列表,指定模块的路径,然后导入模块。例如,给定一个模块位于:
/foo/bar.py
我们可以这样做:
import sys sys.path[0:0] = '/foo' # puts the /foo directory at the start of your path import bar
回答
def import_file(full_path_to_module): try: import os module_dir, module_file = os.path.split(full_path_to_module) module_name, module_ext = os.path.splitext(module_file) save_cwd = os.getcwd() os.chdir(module_dir) module_obj = __import__(module_name) module_obj.__file__ = full_path_to_module globals()[module_name] = module_obj os.chdir(save_cwd) except: raise ImportError import_file('/home/somebody/somemodule.py')
回答
(通过使用imp)向sys.path添加路径的优点是,当从单个包中导入多个模块时,它可以简化操作。例如:
import sys # the mock-0.3.1 dir contains testcase.py, testutils.py & mock.py sys.path.append('/foo/bar/mock-0.3.1') from testcase import TestCase from testutils import RunTests from mock import Mock, sentinel, patch