【发布时间】:2015-04-23 14:45:36
【问题描述】:
给定一个文件的路径,我需要将包名传递给importlib.import_module(),这样相对导入才能正常工作。我无法导入,然后检查module.__package__,因为它不会成功导入。
【问题讨论】:
-
您可以添加您尝试过的内容,包括您的文件夹/文件结构吗?
标签: python packages python-importlib
给定一个文件的路径,我需要将包名传递给importlib.import_module(),这样相对导入才能正常工作。我无法导入,然后检查module.__package__,因为它不会成功导入。
【问题讨论】:
标签: python packages python-importlib
这是一种相当通用的方法:
import pathlib
import sys
def get_module_name(path):
f = pathlib.Path(path).resolve()
for i in map(pathlib.Path, sys.path):
try:
f.relative_to(i)
except ValueError:
pass
else:
*parts, fname = f.relative_to(i).parts
return ".".join(parts), [f.stem]
module, fromlist = get_module_name("Programming/Python/kernprof.py")
print(module, fromlist)
imported_module = __import__(module, fromlist=fromlist)
print(imported_module)
print(getattr(imported_module, fromlist[0]))
输出:
Programming.Python ['kernprof']
<module 'Programming.Python' (namespace)>
<module 'Programming.Python.kernprof' from '/home/matthew/Programming/Python/kernprof.py'>
此解决方案可以处理来自sys.path 的任何路径的导入,但不能进行相对导入(sys.path 以上的导入)。 __import__的使用方法见Why does Python's __import__ require fromlist?。
【讨论】:
__init__s 和 co 会非常复杂,可能会出现一些不需要的结果。
这个助手呢?
import os
def get_parent_package(path):
parent_path = os.path.split(path)[0]
while parent_path != os.sep:
if '__init__.py' in os.listdir(parent_path):
return os.path.basename(parent_path)
parent_path = os.path.split(parent_path)[0]
return None
parent_path != os.sep 如果你在windows下,必须改进。
【讨论】: