¿Por qué no lo mides usando el timeit
módulo ? De esa manera, puede ver si es relevante para su aplicación.
Bien, acabo de intentar lo siguiente:
import timeit
statements=["""\
try:
b = 10/a
except ZeroDivisionError:
pass""",
"""\
if a:
b = 10/a""",
"b = 10/a"]
for a in (1,0):
for s in statements:
t = timeit.Timer(stmt=s, setup='a={}'.format(a))
print("a = {}\n{}".format(a,s))
print("%.2f usec/pass\n" % (1000000 * t.timeit(number=100000)/100000))
Resultado:
a = 1
try:
b = 10/a
except ZeroDivisionError:
pass
0.25 usec/pass
a = 1
if a:
b = 10/a
0.29 usec/pass
a = 1
b = 10/a
0.22 usec/pass
a = 0
try:
b = 10/a
except ZeroDivisionError:
pass
0.57 usec/pass
a = 0
if a:
b = 10/a
0.04 usec/pass
a = 0
b = 10/a
ZeroDivisionError: int division or modulo by zero
Entonces, como se esperaba, no tener ningún controlador de excepciones es un poco más rápido (pero explota en su cara cuando ocurre la excepción) y try/except
es más rápido que un explícito if
siempre que no se cumpla la condición.
Pero todo está dentro del mismo orden de magnitud y es poco probable que importe de cualquier manera. Solo si realmente se cumple la condición, la if
versión es significativamente más rápida.