Ohad Dan
Ohad Dan

Reputation: 2069

Is there a difference between "raise exception()" and "raise exception" without parenthesis?

Defining a parameterless exception:

class MyException(Exception):
    pass

When raised, is there any difference between:

raise MyException

and

raise MyException()

I couldn't find any; is it simply an overloaded syntax?

Upvotes: 146

Views: 16678

Answers (3)

Raymond Hettinger
Raymond Hettinger

Reputation: 226644

The short answer is that both raise MyException and raise MyException() do the same thing. This first form auto instantiates your exception.

The relevant section from the docs says:

raise evaluates the first expression as the exception object. It must be either a subclass or an instance of BaseException. If it is a class, the exception instance will be obtained when needed by instantiating the class with no arguments.

That said, even though the semantics are the same, the first form is microscopically faster, and the second form is more flexible (because you can pass it arguments if needed).

The usual style that most people use in Python (i.e. in the standard library, in popular applications, and in many books) is to use raise MyException when there are no arguments. People only instantiate the exception directly when there some arguments need to be passed. For example: raise KeyError(badkey).

Upvotes: 157

Jason Fried
Jason Fried

Reputation: 117

Go look at the docs for the raise statement. It's creating an instance of MyException.

Upvotes: 5

Ranjith Udayakumar
Ranjith Udayakumar

Reputation: 418

Yep, there is a difference between ValueError and ValueError()

ValueError is a class whereas ValueError() creates an instance of a class. This is the reason the type(ValueError) is type and type(ValueError()) is ValueError

The sole purpose of raise is to raise the exception,

when we use ValueError, class will be called which in turn runs the constructor ValueError()

when we use ValueError(), the method ValueError() is directly called.

Note: raise ValueError # shorthand for 'raise ValueError()'

Upvotes: -3

Related Questions