se è necessario gestire effettivamente le eccezioni:
(modificato dalla risposta di poke53280)
>>> def try_or(fn, exceptions: dict = {}):
try:
return fn()
except Exception as ei:
for e in ei.__class__.__mro__[:-1]:
if e in exceptions: return exceptions[e]()
else:
raise
>>> def context():
return 1 + None
>>> try_or( context, {TypeError: lambda: print('TypeError exception')} )
TypeError exception
>>>
nota che se l'eccezione non è supportata, verrà sollevata come previsto:
>>> try_or( context, {ValueError: lambda: print('ValueError exception')} )
Traceback (most recent call last):
File "<pyshell#57>", line 1, in <module>
try_or( context, {ValueError: lambda: print('ValueError exception')} )
File "<pyshell#38>", line 3, in try_or
return fn()
File "<pyshell#56>", line 2, in context
return 1 + None
TypeError: unsupported operand type(s) for +: 'int' and 'NoneType'
>>>
inoltre, se Exception
viene fornito, corrisponderà a qualsiasi cosa sotto.
( BaseException
è più alto, quindi non corrisponderà)
>>> try_or( context, {Exception: lambda: print('exception')} )
exception