一、try...except
有时候我们写程序的时候,会出现一些错误或异常,导致程序终止。例如,做除法时,除数为0,会引起一个ZeroDivisionError
例子:
|
1
2
3
4
|
a=10
b=0
c=a/b
print "done"
|
运行结果:
Traceback (most recent call last):
File "C:/Users/lirong/PycharmProjects/untitled/openfile.py", line 3, in <module>
c=a/b
ZeroDivisionError: integer division or modulo by zero
我们发现程序因为ZeroDivisionError而中断了,语句print "done" 没有运行。为了处理异常,我们使用try...except,更改代码:
|
1
2
3
4
5
6
7
8
|
a=10
b=0
try:
c=a/b
print c
except ZeroDivisionError,e:
print e.message
print "done"
|
运行结果:
integer division or modulo by zero
done
这样程序就不会因为异常而中断,从而print "done"语句正常执行。
我们把可能发生错误的语句放在try模块里,用except来处理异常。except可以处理一个专门的异常,也可以处理一组圆括号中的异常,如果except后没有指定异常,则默认处理所有的异常。每一个try,都必须至少有一个except
处理一组异常可以这样写(其中e代表异常的实例):
|
1
2
3
4
|
try:
pass
except (IOError ,ZeroDivisionError),e:
print e
|
try ....except...else 语句,当没有异常发生时,else中的语句将会被执行。
例子:
|
1
2
3
4
5
6
7
8
9
10
|
a=10
b=0
try:
c = b/ a
print c
except (IOError ,ZeroDivisionError),x:
print x
else:
print "no error"
print "done"
|
运行结果:
0
no error
done
二、raise 引发一个异常
例子:如果输入的数据不是整数,则引发一个ValueError
|
1
2
3
4
5
|
inputValue=input("please input a int data :")
if type(inputValue)!=type(1):
raise ValueError
else:
print inputValue
|
假设输入1.2,运行结果为:
please input a int data :1.2
Traceback (most recent call last):
File "C:/Users/lirong/PycharmProjects/untitled/openfile.py", line 3, in <module>
raise ValueError
ValueError
如果输入1,运行结果为:
please input a int data :1
1
三、try ...finally
无论异常是否发生,在程序结束前,finally中的语句都会被执行。
|
1
2
3
4
5
6
|
a=10
b=0
try:
print a/b
finally:
print "always excute"
|
运行结果:
Traceback (most recent call last):
always excute
File "C:/Users/lirong/PycharmProjects/untitled/openfile.py", line 4, in <module>
print a/b
ZeroDivisionError: integer division or modulo by zero
虽然有异常发生,但在程序终止前,finally中的语句也能正常执行。。
finally语句也可以和except语句一起使用。
|
1
2
3
4
5
6
7
8
|
a=10
b=0
try:
print a/b
except:
print "error"
finally:
print "always excute"
|
运行结果:
error
always excute
四、自定义一个异常类
自定义一个MyException类,继承Exception。
|
1
2
3
4
|
class MyException(Exception):
def __init__(self,message):
Exception.__init__(self)
self.message=message
|
如果输入的数字小于10,就引发一个MyException异常:
|
1
2
3
4
5
6
|
a=input("please input a num:")
if a<10:
try:
raise MyException("my excepition is raised ")
except MyException,e:
print e.message
|
运行结果:
please input a num:1
my excepition is raised
五、python所有的标准异常类:
| 异常名称 | 描述 |
| BaseException |
所有异常的基类 |
| SystemExit |
解释器请求退出 |
| KeyboardInterrupt |
用户中断执行(通常是输入^C) |
| Exception |
常规错误的基类 |
| StopIteration |
迭代器没有更多的值 |
| GeneratorExit |
生成器(generator)发生异常来通知退出 |
| SystemExit |
Python 解释器请求退出 |
| StandardError |
所有的内建标准异常的基类 |
| ArithmeticError |
所有数值计算错误的基类 |
| FloatingPointError |
浮点计算错误 |
| OverflowError |
数值运算超出最大限制 |
| ZeroDivisionError |
除(或取模)零 (所有数据类型) |
| AssertionError |
断言语句失败 |
| AttributeError |
对象没有这个属性 |
| EOFError |
没有内建输入,到达EOF 标记 |
| EnvironmentError |
操作系统错误的基类 |
| IOError |
输入/输出操作失败 |
| OSError |
操作系统错误 |
| WindowsError |
系统调用失败 |
| ImportError |
导入模块/对象失败 |
| KeyboardInterrupt |
用户中断执行(通常是输入^C) |
| LookupError |
无效数据查询的基类 |
| IndexError |
序列中没有没有此索引(index) |
| KeyError |
映射中没有这个键 |
| MemoryError |
内存溢出错误(对于Python 解释器不是致命的) |
| NameError |
未声明/初始化对象 (没有属性) |
| UnboundLocalError |
访问未初始化的本地变量 |
| ReferenceError |
弱引用(Weak reference)试图访问已经垃圾回收了的对象 |
| RuntimeError |
一般的运行时错误 |
| NotImplementedError |
尚未实现的方法 |
| SyntaxError |
Python 语法错误 |
| IndentationError |
缩进错误 |
| TabError |
Tab 和空格混用 |
| SystemError |
一般的解释器系统错误 |
| TypeError |
对类型无效的操作 |
| ValueError |
传入无效的参数 |
| UnicodeError |
Unicode 相关的错误 |
| UnicodeDecodeError |
Unicode 解码时的错误 |
| UnicodeEncodeError |
Unicode 编码时错误 |
| UnicodeTranslateError |
Unicode 转换时错误 |
| Warning |
警告的基类 |
| DeprecationWarning |
关于被弃用的特征的警告 |
| FutureWarning |
关于构造将来语义会有改变的警告 |
| OverflowWarning |
旧的关于自动提升为长整型(long)的警告 |
| PendingDeprecationWarning |
关于特性将会被废弃的警告 |
| RuntimeWarning |
可疑的运行时行为(runtime behavior)的警告 |
| SyntaxWarning |
可疑的语法的警告 |
| UserWarning |
用户代码生成的警告 |