Say I have a
class Rocket(object):
def __init__(self):
self.ready = False
def prepare_for_takeoff(self):
self.ready = True
def takeoff(self):
if not self.ready:
raise NotReadyException("not ready!")
print("Liftoff!")
Now, which of the standard exceptions would be most appropriate to derive NotReadyException from? Would it be ValueError, since self has the wrong state/value?
ExceptionDon’t mess with anything else.
http://code.google.com/p/soc/wiki/PythonStyleGuide#Exceptions
What are your use cases for exception handling?
If you derived your exception from, say
ValueError, would you ever write a handler that usedexcept ValueError:to catch both exceptions and handle them in exactly the same way? Unlikely.ValueErroris a catch-all when more specific exceptions aren’t appropriate. Your exception is very specific.When you have an application-specific exception like this, the odds of it sharing any useful semantics with a built-in exception are low. The odds of actually combining the new one and an existing exception into a single handler are very, very low.
About the only time you’ll ever combine an application-specific exception with generic exceptions is to use
except Exception:in some catch-all logger.