在python程序执行过程中(在其他编程语言中也是一样),难免会由于各种意想不到的情况导致程序运行异常而报错。而这个时候就需要通过使用异常处理来对运行过程中出现的异常进行处理。
try ... except ...
try ... except ... 是异常处理中基本的模式。在正常的执行一段代码的过程中,当遇到异常的时候,程序就会报错而停止运行。如下
a = 1
b = 0
c = a/b
print "finish!"
运行结果输出如下,并停止整个程序,而无法打印出 "finish!"
ZeroDivisionErrorTraceback (most recent call last)
<ipython-input-52-e24740cac162> in <module>()
1 a = 1
2 b = 0
----> 3 c = a/b
4 print "finish!"ZeroDivisionError: integer division or modulo by zero
而如果使用try ... except ... ,当程序在try代码块中运行出现异常,则程序会跳到except代码块中运行,在except代码块中可以进行相关的异常处理,执行完except代码块中的程序之后,程序依旧能够继续运行。代码如下
try:
a = 1
b = 0
c = a/b
except:
print "分母不能为 0 哦!"
print "finish!"
上如代码执行结果如下:
分母不能为 0 哦!
finish!
该代码在执行try代码块中的代码时出错,跳转执行except中的代码输出 "分母不能为 0 哦!" 以提醒工作人员,并执行最后一句打印出了 "finish!"。
try ... except Exception as e ...
而在实际程序运行过程,异常情况的出现并非坏事,它能够帮助我们了解我们自己的代码中有哪些情况没有考虑到,而如果简单粗暴的使用”try ... except ... “来直接跳过异常情况,虽然代码能够继续执行,但是无法捕捉到底是为什么出了问题。如何能够即让程序继续执行,同时又使程序能够报出异常原因?此时,可以使用"try ... except Exception as e ..."来实现。代码如下:
try:
a = 1
b = 0
c = a/b
except Exception as e:
print e
print "finish!"
上述代码输出结果如下。该代码既能够通过输出产生异常的原因,同时也能够使程序继续执行,输出“finish!”。
integer division or modulo by zero
finish!
其中,Exception是python中的一种标准异常,而在python中这种标准异常有很多,如下:
异常名称 | 描述 |
---|---|
BaseException | 所有异常的基类 |
SystemExit | 解释器请求退出 |
KeyboardInterrupt | 用户中断执行(通常是输入^C) |
Exception | 常规错误的基类 |
StopIteration | 迭代器没有更多的值 |
GeneratorExit | 生成器(generator)发生异常来通知退出 |
StandardError | 所有的内建标准异常的基类 |
ArithmeticError | 所有数值计算错误的基类 |
FloatingPointError | 浮点计算错误 |
OverflowError | 数值运算超出最大限制 |
ZeroDivisionError | 除(或取模)零 (所有数据类型) |
AssertionError | 断言语句失败 |
AttributeError | 对象没有这个属性 |
EOFError | 没有内建输入,到达EOF 标记 |
EnvironmentError | 操作系统错误的基类 |
IOError | 输入/输出操作失败 |
OSError | 操作系统错误 |
WindowsError | 系统调用失败 |
ImportError | 导入模块/对象失败 |
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 ... finally ...
上述代码中最后的print “finish!”语句也可以放在finally代码块中。finally代码块的作用就是不论在try中的代码是否出现异常,最终都会去执行finally中的代码。如下:
try ... except ... finally ... 示例1
try:
a = 1
b = 0
c = a/b
except Exception as e:
print e
finally:
print "finish!"
示例1输出结果如下:
integer division or modulo by zero
finish!
try ... except ... finally ... 示例2
try:
a = 1
b = 2
c = a/b
except Exception as e:
print e
finally:
print "finish!"
示例2输出结果如下:
finish!
上述两段代码会根据在try中是否遇到异常而选择是否执行except中的代码,但最终总是会执行finally中的代码。
网友评论