一、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 |
用户代码生成的警告 |