si vous devez réellement gérer les exceptions:
(modifié de la réponse de 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
>>>
notez que si l'exception n'est pas prise en charge, elle se déclenchera comme prévu:
>>> 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'
>>>
aussi si Exception
est donné, il correspondra à tout ce qui suit.
( BaseException
est plus élevé, donc il ne correspondra pas)
>>> try_or( context, {Exception: lambda: print('exception')} )
exception