zoukankan      html  css  js  c++  java
  • Python中获取异常(Exception)信息

    异常信息的获取对于程序的调试非常重要,可以有助于快速定位有错误程序语句的位置。下面介绍几种python中获取异常信息的方法,这里获取异常(Exception)信息采用try...except...程序结构。如下所示

    复制代码
    try:
    
      ...
    
    except Exception as e:
    
      ...
    复制代码

    1、str(e)

    返回字符串类型,只给出异常信息,不包括异常信息的类型,如1/0的异常信息

    'integer division or modulo by zero'

    2、repr(e)

    给出较全的异常信息,包括异常信息的类型,如1/0的异常信息

    "ZeroDivisionError('integer division or modulo by zero',)"

    3、e.message

    获得的信息同str(e)

    4、采用traceback模块

      需要导入traceback模块,此时获取的信息最全,与python命令行运行程序出现错误信息一致。使用traceback.print_exc()打印异常信息到标准错误,就像没有获取一样,或者使用traceback.format_exc()将同样的输出获取为字符串。你可以向这些函数传递各种各样的参数来限制输出,或者重新打印到像文件类型的对象。

    示例如下:

    复制代码
    import traceback
    
    print '########################################################'
    print "1/0 Exception Info"
    print '---------------------------------------------------------'
    try:
        1/0
    except Exception as e:
        print 'str(Exception):	', str(Exception)
        print 'str(e):		', str(e)
        print 'repr(e):	', repr(e)
        print 'e.message:	', e.message
        print 'traceback.print_exc():'; traceback.print_exc()
        print 'traceback.format_exc():
    %s' % traceback.format_exc()
    print '########################################################'
    print '
    ########################################################'  
    print "i = int('a') Exception Info"
    print '---------------------------------------------------------'
    try:
        i = int('a')
    except Exception as e:
        print 'str(Exception):	', str(Exception)
        print 'str(e):		', str(e)
        print 'repr(e):	', repr(e)
        print 'e.message:	', e.message
        print 'traceback.print_exc():'; traceback.print_exc()
        print 'traceback.format_exc():
    %s' % traceback.format_exc()
    print '########################################################' 
    复制代码

    示例结果

  • 相关阅读:
    Mybatis--->第五节注解完成增删改查
    Mybatis--->新增新功能报错,以前都正常,突然报错
    Mybatis--->limit分页查询
    固定套路--->log4j日志运用-Maven
    Mybatis第三节优化别名--->user
    Mybatis入门第二节--->优化
    Mybatis 报错 java.io.IOException: Could not find resource mybatis-config.xml
    学习Java的第十二天
    学习Java的第十一天
    学习Java的第十天
  • 原文地址:https://www.cnblogs.com/hushaojun/p/6227271.html
Copyright © 2011-2022 走看看