Python异常管理

Python提供了向java一样的非常丰富的异常类。


1、NameError:尝试访问一个未申明的变量
>>>  v
NameError: name 'v' is not defined

2、ZeroDivisionError:除数为0
>>> v = 1/0
ZeroDivisionError: int division or modulo by zero

3、SyntaxError:语法错误
>>> int int
SyntaxError: invalid syntax (<pyshell#14>, line 1)

4、IndexError:索引超出范围
>>> List = [2]
>>> List[3]
Traceback (most recent call last):
  File "<pyshell#18>", line 1, in <module>
    List[3]
IndexError: list index out of range

5、KeyError:字典关键字不存在
>>> Dic = {'1':'yes', '2':'no'}
>>> Dic['3']
Traceback (most recent call last):
  File "<pyshell#20>", line 1, in <module>
    Dic['3']
KeyError: '3'

6、IOError:输入输出错误
>>> f = open('abc')
IOError: [Errno 2] No such file or directory: 'abc'

7、AttributeError:访问未知对象属性
>>> class Worker:
 def Work():
  print("I am working")

>>> w = Worker()
>>> w.a
Traceback (most recent call last):
  File "<pyshell#51>", line 1, in <module>
    w.a
AttributeError: 'Worker' object has no attribute 'a'

8、ValueError:数值错误
>>> int('d')
Traceback (most recent call last):
  File "<pyshell#54>", line 1, in <module>
    int('d')
ValueError: invalid literal for int() with base 10: 'd'

9、TypeError:类型错误
>>> iStr = '22'
>>> iVal = 22
>>> obj = iStr + iVal;
Traceback (most recent call last):
  File "<pyshell#68>", line 1, in <module>
    obj = iStr + iVal;
TypeError: Can't convert 'int' object to str implicitly

10、AssertionError:断言错误
>>> assert 1 != 1
Traceback (most recent call last):
  File "<pyshell#70>", line 1, in <module>
    assert 1 != 1
AssertionError

以上转自http://blog.csdn.net/fcoolx/article/details/4202872

下面增加一些本人工作过程中遇到过的异常:

11、MemoryError:内存耗尽异常

12、NotImplementedError:方法没实现引起的异常

    示例:

复制代码
1 class Base(object):
2     def __init__(self):
3         pass
4 
5     def action(self):
6         raise NotImplementedError
复制代码

定义一个类,一个接口方法action,如果直接调用action则抛NotImplementedError异常,这样做的目的通常是用来模拟接口

13、LookupError:键、值不存在引发的异常

    LookupError异常是IndexError、KeyError的基类

   如果你不确定数据类型是字典还是列表时,可以用LookupError捕获此异常

14、StandardError 标准异常。

    除StopIterationGeneratorExitKeyboardInterrupt 和SystemExit外,其他异常都是StandarError的子类。


抛出异常的方法

例如输出一个数倒数的函数

def test(a):
    try:
        b = 1/a
        print(b)
    except ZeroDivisionError as e: //除数为零的异常
        print(e)
    except Exception as e:         //其他异常,例如传入a是一个字符串
        print("unknown error") 
    finally:                       //最终执行的的语句
        print("exec the function")


尤其注意

 except Exception as e:
在python2.x中,

 except Exception, e:
也是合法的,但在python3.x中,会报错,因此最好写成第一种形式,2,3均支持



另外,http://zengrong.net/post/2143.htm 做了如下总结

使用 sys.exc_info() 和 sys.last_traceback

sys.exc_info() 会返回一个3值元表,其中包含调用该命令时捕获的异常。

这个元表的内容为 (type, value, traceback) ,其中:

  • type 从获取到的异常中得到类型名称,它是BaseException 的子类;
  • value 是捕获到的异常实例;
  • traceback 是一个 traceback 对象,下面会详述。

sys.last_traceback 包含的内容与 sys.exc_info() 相同,但它主要用于调试,并不总是被定义。

import sys
try:
    raise
except:
    t,v,tb = sys.exc_info()
    print(t,v)

使用 traceback

trackback 模块用来精确模仿 python3 解析器的 stack trace 行为。在程序中应该尽量使用这个模块。

traceback.print_exc() 可以直接打印当前的异常。

import traceback
try:
    raise
except:
    traceback.print_exc()

traceback.print_tb() 用来打印上面提到的 trackback 对象。

import sys,traceback
try:
    raise
except:
    t,v,tb = sys.exc_info()
    traceback.print_tb(tb)

traceback.print_exception() 可以直接打印 sys.exc_info() 提供的元表。

import sys,traceback
try:
    raise
except:
    traceback.print_exception(*sys.exc_info())

但是,如果你还想把这些异常保存到一个日志文件中,来分析这些异常,那么请看下面的方法:

把 traceback.print_exc() 打印在屏幕上的信息保存到一个文本文件中

1
2
3
4
5
6
7
8
9
import  traceback
try :  
     a = b  
     b = c  
except :  
     f = open ( "c:log.txt" , 'a' )  
     traceback.print_exc( file = f)  
     f.flush()  
     f.close()

其实,下面两句是等价的:

  • traceback.print_exc()
  • traceback.print_exception(*sys.exc_info())

traceback 提供的参数可以将 print 的内容写入到文件中,详见这里:29.9. traceback — Print or retrieve a stack traceback




转载于:https://www.cnblogs.com/wujiazhong/p/9526985.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值