One-Line Exception Handling
It is not possible to do a one-line exception-handling statement in python. One could write a function to do this.
def safe_execute(default, exception, function, *args):
try:
return function(*args)
except exception:
return default
Example usage:
from json import loads
safe_execute("Oh no, explosions occurred!", TypeError, loads, None)
# Returns "Oh no, explosions occurred!"
safe_execute("Huh?", TypeError, int, "10")
#Returns 10
Multiple arguments are supported
from operator import div
safe_execute(
"Divsion by zero is invalid.",
ZeroDivisionError,
div, 1, 0
)
# Returns "Divsion by zero is invalid."
safe_execute(
"Divsion by zero is invalid.",
ZeroDivisionError,
div, 1, 1
)
# Returns 1.
The error-catching process may still be interrupted:
from time import sleep
safe_execute(
"Panic!",
Exception,
sleep, 8
)
# Ctrl-c will raise a KeyboardInterrupt
from sys import exit
safe_execute("Failed to exit!", Exception, exit)
# Exits the Python interpreter
If this behavior is undesired, use BaseException
:
from time import sleep
safe_execute("interrupted",
BaseException,
sleep, 8)
#Pressing Ctrl-c will return "interrupted"
from sys import exit
safe_execute("Naughty little program!",
BaseException,
exit)
#Returns "Naughty little program!"
It is possible in one line using exec:
parse_float = lambda x, y=exec("def f(s):\n try:\n return float(s)\n except: return None"): f(x)
You can use contextlib
to suppress
exceptions. If you like to live dangerously you could suppress BaseException
, which would suppress all builtin exceptions (probably a bad idea). Or you could pick a safe one relevant to your code, like TypeError
.
examples:
from contextlib import suppress
# this will execute right along
with suppress(BaseException): fhasldjkfhsa345315
# even raising an Exception will fly just fine
with suppress(BaseException): raise NameError
# correct code will execute just fine
x=5
with suppress(BaseException): x+=2
print(x) # prints 7
# and in your example:
from json import loads
pleasure = suppress(TypeError) # so each line rolls off the tongue :)
with pleasure: result = loads('{"value": True}')
print(result) # prints {'value': True}
with pleasure: result = loads(None)
print(result) # prints {'value': True} because result never changed