我想用一个也应该捕获异常的包装器来包装默认的 open 方法。这是一个有效的测试示例:
truemethod = open
def fn(*args, **kwargs):
try:
return truemethod(*args, **kwargs)
except (IOError, OSError):
sys.exit('Can\'t open \'{0}\'. Error #{1[0]}: {1[1]}'.format(args[0], sys.exc_info()[1].args))
open = fn
我想做一个通用的方法:
def wrap(method, exceptions = (OSError, IOError)):
truemethod = method
def fn(*args, **kwargs):
try:
return truemethod(*args, **kwargs)
except exceptions:
sys.exit('Can\'t open \'{0}\'. Error #{1[0]}: {1[1]}'.format(args[0], sys.exc_info()[1].args))
method = fn
但它不起作用:
>>> wrap(open)
>>> open
<built-in function open>
显然,method
是参数的副本,而不是我预期的引用。任何pythonic解决方法?