我最近问这个question关于在python中导入任意数量的模块。我收到了两个很好的答案。当我在spyder中对其编程时,两者都起作用。
由于我计划将代码移至服务器,因此今天我从终端运行了该脚本作为测试。但这一次脚本因此Traceback而崩溃:
File "evaluation.py", line 27, in __init__
self.solvers.append( __import__(file_name[:-3]) ) #cut away .py
ImportError: No module named 'v00'
文件体系结构如下:
-evaluation.py
-evaluation
-v00.py
-v01.py
valuation.py中引起麻烦的代码是这一段:
os.chdir('evaluation')
for file_name in glob.glob("*.py"):
self.solvers.append( __import__(file_name[:-3]) ) #cut away .py
for idx, solver in enumerate(self.solvers):
self.dqn.append(solver.DQNSolver() )
为什么这在spyder中起作用但在终端中不起作用?他们都使用python 3.5,执行恶意代码时,我再次检查了它们是否都在“评估”文件夹中。
答案 0 :(得分:2)
典型的处理方法是通过添加一个空的__init__.py
文件将文件夹变成一个包,然后使用import evaluation.v00
(或等效的__import__
函数)从包中导入呼叫)。但是您可能会遇到问题,因为您的主脚本与软件包的名称相同。我建议重命名一个或另一个
-evaluationscript.py
-evaluation
-__init__.py (empty file)
-v00.py
-v01.py
然后您可能需要使用import_module而不是__import__
来用实际模块(而不是软件包)填充solvers
。
我对spyder并不熟悉,但是如果相同的代码在那里工作,则可能是使用PYTHONPATH
env var或通过修改{{1} }。
运行脚本时,脚本的路径会添加到模块导入的默认搜索路径中,但是使用sys.path
更改文件夹不会影响该搜索路径。