一、try...except
有时候我们写程序的时候,会出现一些错误或异常,导致程序终止。例如,做除法时,除数为0,会引起一个ZeroDivisionError
例子:
a=10b=0c=a/bprint "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,更改代码:
a=10b=0try:    c=a/b    print cexcept ZeroDivisionError,e:    print e.messageprint "done"
运行结果:
integer division or modulo by zero
done
这样程序就不会因为异常而中断,从而print "done"语句正常执行。
我们把可能发生错误的语句放在try模块里,用except来处理异常。except可以处理一个专门的异常,也可以处理一组圆括号中的异常,如果except后没有指定异常,则默认处理所有的异常。每一个try,都必须至少有一个except
处理一组异常可以这样写(其中e代表异常的实例):
try:    passexcept (IOError ,ZeroDivisionError),e:    print etry ....except...else 语句,当没有异常发生时,else中的语句将会被执行。
例子:
a=10b=0try:    c = b/ a    print cexcept (IOError ,ZeroDivisionError),x:    print xelse:    print "no error"print "done"运行结果:
0
no error
done
二、raise 引发一个异常
例子:如果输入的数据不是整数,则引发一个ValueError
inputValue=input("please input a int data :")if type(inputValue)!=type(1):    raise ValueErrorelse:    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中的语句都会被执行。
a=10b=0try:    print a/bfinally:    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语句一起使用。
a=10b=0try:    print a/bexcept:    print "error"finally:    print "always excute"运行结果:
error
always excute
四、自定义一个异常类
自定义一个MyException类,继承Exception。
class MyException(Exception):    def __init__(self,message):        Exception.__init__(self)        self.message=message  
如果输入的数字小于10,就引发一个MyException异常:
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 | 用户代码生成的警告 | 
一、try...except
有时候我们写程序的时候,会出现一些错误或异常,导致程序终止。例如,做除法时,除数为0,会引起一个ZeroDivisionError
例子:
| 1 2 3 4 | a=10b=0c=a/bprint"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=10b=0try:    c=a/b    printcexceptZeroDivisionError,e:    printe.messageprint"done" | 
运行结果:
integer division or modulo by zero
done
这样程序就不会因为异常而中断,从而print "done"语句正常执行。
我们把可能发生错误的语句放在try模块里,用except来处理异常。except可以处理一个专门的异常,也可以处理一组圆括号中的异常,如果except后没有指定异常,则默认处理所有的异常。每一个try,都必须至少有一个except
处理一组异常可以这样写(其中e代表异常的实例):
| 1 2 3 4 | try:    passexcept(IOError ,ZeroDivisionError),e:    printe | 
try ....except...else 语句,当没有异常发生时,else中的语句将会被执行。
例子:
| 1 2 3 4 5 6 7 8 9 10 | a=10b=0try:    c =b/a    printcexcept(IOError ,ZeroDivisionError),x:    printxelse:    print"no error"print"done" | 
运行结果:
0
no error
done
二、raise 引发一个异常
例子:如果输入的数据不是整数,则引发一个ValueError
| 1 2 3 4 5 | inputValue=input("please input a int data :")iftype(inputValue)!=type(1):    raiseValueErrorelse:    printinputValue | 
假设输入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=10b=0try:    printa/bfinally:    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=10b=0try:    printa/bexcept:    print"error"finally:    print"always excute" | 
运行结果:
error
always excute
四、自定义一个异常类
自定义一个MyException类,继承Exception。
| 1 2 3 4 | classMyException(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:")ifa<10:    try:        raiseMyException("my excepition is raised ")    exceptMyException,e:        printe.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 | 用户代码生成的警告 | 
原文:http://www.cnblogs.com/baotou/p/7496579.html