views:

985

answers:

4

If I want to open binary file (in Python 2.6), that doesn't exists, program exits with an error and prints this:

    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'

Does anybody know, 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, program would not exits, and I would have useful information.

+8  A: 

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()
Ned Batchelder
+2  A: 

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()
THC4k
A: 

Thanks for all.

That's, what I needed :)

import traceback

try:
    # boom
except Exception:
    print traceback.format_exc()
TurboJupi
You shouldn't create an answer when you're making a comment. Accept one of the answers to reward your helpers!
Ned Batchelder
Please take the time to take another look at Ned B's answer. There are several important points that he makes, beyond just solving your immediate problem.
Paul McGuire
Thanks, Paul, but I have a feeling we've reached the end of activity on this question...
Ned Batchelder
+3  A: 

I just wanted to note one thing, and that is 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.

jathanism