今天小编就为大家分享一篇python打印异常信息的两种实现方式,具有很好的参考价值,希望对大家有所帮助。

一起跟随小编过来看看吧:

1. 直接打印错误

输出异常概要信息,但是缺少行定位,不方便调试。

try:
    # your code
except KeyboardInterrupt:
    print("quit")
except Exception as ex:
    print("出现如下异常%s"%ex)

例子:

try:
    2/0
except Exception as e:
    print(e)

输出:division by zero

2.用traceback模块打印

输出具体错误的异常信息,如行数,方便调试的时候定位,因此用traceback模块更方便调试。

import traceback
try:
    2/0
except Exception as e:
    traceback.print_exc()

输出:

Traceback (most recent call last):
    File "c:\Users\Administrator\Desktop\test1.py", line 3, in <module>
    2/0
ZeroDivisionError: division by zero

ps:上述traceback.print_exc()是直接打印错误

还可以用traceback.format_exc()返回字符串,可将错误信息保存在文档日志中。可以说traceback.print_exc()等同于print traceback.format_exc()。