删除这样的内置函数后,我想在不重新启动解释器的情况下恢复它。
>>> import builtins
>>> del builtins.eval
>>> builtins.eval = None
我尝试使用importlib
重新加载内置模块,但没有恢复eval。
>>> import importlib
>>> importlib.reload(builtins)
<module 'builtins' (built-in)>
>>> eval("5 + 5")
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'NoneType' object is not callable
我还尝试从另一个模块分配一个__builtins__
变量。但效果不佳。
>>> import os
>>> __builtins__ = os.__builtins__
>>> eval()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'NoneType' object is not callable
有没有办法在删除内置函数后恢复它?
我认为builtins
的使用模式与您建议的不同。您通常要做的是为您的目的重新绑定一个内置名称,然后使用builtins
来恢复功能:
eval = None
eval('5 + 5')
# TypeError: 'NoneType' object is not callable
import builtins
eval = builtins.eval
eval('5 + 5')
# 10
或者(正如@ShadowRanger评论的那样(,在这个特定的案例中更简单:
eval = None
eval('5 + 5')
# TypeError: 'NoneType' object is not callable
del eval
eval('5 + 5')
# 10
发布问题后,我找到了一种使用BuiltinImporter恢复问题的方法。
>>> import builtins
>>> del builtins.eval
>>> builtins.eval = None
>>> eval()
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: 'NoneType' object is not callable
>>> import importlib
>>> bi = importlib.machinery.BuiltinImporter
>>> bi.load_module("builtins")
<module 'builtins' (built-in)>
>>> import sys
>>> __builtins__ = bi.load_module.__globals__['module_from_spec'](sys.modules['builtins'].__spec__)
>>> eval("5 + 5")
10