Ales Kancilija
Ales Kancilija

Reputation: 894

Exception message (Python 2.6)

In Python, if I open a binary file that doesn't exist, the program exits with an error and prints:

Traceback (most recent call last):
  File "C:\Python_tests\Exception_Handling\src\exception_handling.py", 
  line 4, in <module>
  pkl_file = open('monitor.dat', 'rb')
  IOError: [Errno 2] No such file or directory: 'monitor.dat'

I can handle this with 'try-except', like:

try:
    pkl_file = open('monitor.dat', 'rb')
    monitoring_pickle = pickle.load(pkl_file)
    pkl_file.close()
except Exception:
    print 'No such file or directory'

How could I, in caught Exception, print the following line?

File "C:\Python_tests\Exception_Handling\src\exception_handling.py", 
line 11, in <module>
pkl_file = open('monitor.dat', 'rb')

So the program would not exit.

Upvotes: 35

Views: 84067

Answers (4)

jathanism
jathanism

Reputation: 33716

If you want to capture the exception object passed by the Exception, it's best to start using the NEW format introduced in Python 2.6 (which currently supports both) because it will be the only way to do it into Python 3.

And that is:

try:
    ...
except IOError as e:
    ...

Example:

try:
    pkfile = open('monitor.dat', 'rb')
except IOError as e:
    print 'Exception error is: %s' % e

A detailed overview can be found at the What's New in Python 2.6 documentation.

Upvotes: 22

Ales Kancilija
Ales Kancilija

Reputation: 894

Thanks for all.

That's, what I needed :)

import traceback

try:
    # boom
except Exception:
    print traceback.format_exc()

Upvotes: 6

Ned Batchelder
Ned Batchelder

Reputation: 375634

This prints the exception message:

except Exception, e:
    print "Couldn't do it: %s" % e

This will show the whole traceback:

import traceback

# ...

except Exception, e:
    traceback.print_exc()

But you might not want to catch Exception. The narrower you can make your catch, the better, generally. So you might want to try:

except IOError, e:

instead. Also on the subject of narrowing your exception handling, if you are only concerned about missing files, then put the try-except only around the open:

try:
    pkl_file = open('monitor.dat', 'rb')
except IOError, e:
    print 'No such file or directory: %s' % e

monitoring_pickle = pickle.load(pkl_file)
pkl_file.close()

Upvotes: 89

Jochen Ritzel
Jochen Ritzel

Reputation: 107638

Python has the traceback module.

import traceback
try:
    pkl_file = open('monitor.dat', 'rb')
    monitoring_pickle = pickle.load(pkl_file)
    pkl_file.close()
except IOError:
    traceback.print_exc()

Upvotes: 9

Related Questions