异常处理

在python程序执行过程中(在其他编程语言中也是一样),难免会由于各种意想不到的情况导致程序运行异常而报错。而这个时候就需要通过使用异常处理来对运行过程中出现的异常进行处理。

try … except …

try … except … 是异常处理中基本的模式。在正常的执行一段代码的过程中,当遇到异常的时候,程序就会报错而停止运行。如下

a = 1
b = 0
c = a/b
print "finish!"

运行结果输出如下,并停止整个程序,而无法打印出 “finish!”

ZeroDivisionErrorTraceback (most recent call last)
in ()
​ 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!"

上述代码输出结果如下。该代码既能够通过ee输出产生异常的原因,同时也能够使程序继续执行,输出*“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中的代码。

展开阅读全文

没有更多推荐了,返回首页