在使用 IPython 在 Python 中开发一个大型项目(拆分为多个文件和文件夹)时,我遇到了缓存导入模块的麻烦。
问题是指令import module
只读取该模块一次,即使该模块已更改!所以每次我更改包中的某些内容时,我都必须退出并重新启动 IPython。痛苦。
有没有办法正确强制重新加载某些模块?或者,更好的是,以某种方式阻止 Python 缓存它们?
我尝试了几种方法,但都没有奏效。特别是我遇到了非常非常奇怪的错误,例如某些模块或变量神秘地等于None
...
我发现的唯一明智的资源是Reloading Python modules,来自 pyunit,但我没有检查它。我想要那样的东西。
一个不错的选择是让 IPython 重新启动,或者以某种方式重新启动 Python 解释器。
那么,如果你用 Python 开发,你找到了什么样的解决方案来解决这个问题呢?
编辑
说清楚:显然,我知道一些旧变量取决于模块的先前状态可能会保留。那个我能接受。为什么在 Python 中强制重新加载模块而不发生各种奇怪的错误如此困难?
更具体地说,如果我将整个模块放在一个文件中module.py
,则以下内容可以正常工作:
import sys
try:
del sys.modules['module']
except AttributeError:
pass
import module
obj = module.my_class()
这段代码工作得很好,我可以在几个月内不退出 IPython 的情况下进行开发。
但是,每当我的模块由几个子模块组成时,地狱就会崩溃:
import os
for mod in ['module.submod1', 'module.submod2']:
try:
del sys.module[mod]
except AttributeError:
pass
# sometimes this works, sometimes not. WHY?
为什么无论我将模块放在一个大文件中还是在多个子模块中,Python 会有如此不同?为什么这种方法不起作用?