我经常在Python解释器中测试我的模块,当我看到错误时,我会快速更新.py文件。但是我如何让它反映在解释器上呢?所以,到目前为止,我一直在退出并重新进入解释器,因为重新导入文件再次不适合我。


当前回答

上面所有关于reload()或imp.reload()的答案都已弃用。

Reload()不再是python 3中的内置函数,并且imp. Reload()被标记为已弃用(参见help(imp))。

最好使用importlib.reload()。

其他回答

这里有一个很好的解释,说明你的依赖模块不会被重新加载,以及可能产生的影响:

http://pyunit.sourceforge.net/notes/reloading.html

pyunit解决这个问题的方法是通过覆盖__import__来跟踪依赖模块,然后从sys. exe中删除每个模块。模块并重新导入。不过他们可能只是装弹而已。

简短的回答:

尝试使用reimport:一个完整的Python重载。

再答:

看起来这个问题是在reimport发布之前被问到/回答的,reimport自称是“Python的全功能重载”:

This module intends to be a full featured replacement for Python's reload function. It is targeted towards making a reload that works for Python plugins and extensions used by longer running applications. Reimport currently supports Python 2.4 through 2.6. By its very nature, this is not a completely solvable problem. The goal of this module is to make the most common sorts of updates work well. It also allows individual modules and package to assist in the process. A more detailed description of what happens is on the overview page.

注意:虽然重新导入显式地支持Python 2.4到2.6,但我一直在2.7上尝试它,它似乎工作得很好。

所以,到目前为止,我一直在退出并重新进入解释器,因为重新导入文件再次不适合我。

是的,只要再次输入import,就会得到sys.modules中模块的现有副本。

你可以用reload(module)来更新sys。模块并获得该模块的新副本,但如果任何其他模块引用了原始模块或来自原始模块的任何对象,它们将保留旧的引用,并且会发生非常混乱的事情。

So if you've got a module a, which depends on module b, and b changes, you have to ‘reload b’ followed by ‘reload a’. If you've got two modules which depend on each other, which is extremely common when those modules are part of the same package, you can't reload them both: if you reload p.a it'll get a reference to the old p.b, and vice versa. The only way to do it is to unload them both at once by deleting their items from sys.modules, before importing them again. This is icky and has some practical pitfalls to do with modules entries being None as a failed-relative-import marker.

如果你有一个模块将其对象的引用传递给系统模块——例如它注册了一个编解码器,或者添加了一个警告处理程序——你就卡住了;你无法在不混淆Python环境的情况下重新加载系统模块。

总之:除了最简单的情况外,对于由一个独立脚本加载一个自包含模块的所有情况,reload()是非常棘手的;如果像你暗示的那样,你正在使用一个“包”,你可能会更好地继续循环解释器。

不确定这是否完成了所有预期的事情,但你可以这样做:

>>> del mymodule
>>> import mymodule

蜻蜓的回答对我有用(python 3.4.3)。

import sys
del sys.modules['module_name']

下面是一个较低层次的解决方案:

exec(open("MyClass.py").read(), globals())