程序员最大的天敌就是bug,所谓bug就是按照特定的输入,却没有得到期望的相应,这个时候程序出了bug。bug是一定会存在的,有些是人为因素造成的,所以在编程的时候,我们要采取措施,尽量的减少bug的出现。python内置了我们常用到的异常处理机制,比如断言,在编程的过程中,合理的使用这些异常处理机制,能帮我们减少很多调试代码的时间。本文主要介绍一些异常处理机制的使用。
这种方式涉及到我们的编程习惯。我们可以定义一种返回错误码,例如-1,此时可以通过函数的返回值来定位错误的位置。
def func(x):
if isinstance(x,int):
return x
else:
return -1
res = func(1)
print(res)
res = func('1')
print(res)
python中最常用的就是try…这种机制,需要注意的是:try, except, finally 三部分是独立的,所以没有except或者finally都是可以的。
try:
do right thing
except:
do error thing
finally:
do another thing
try中是正常运行的代码,except中是出现异常后运行的代码,finally中是一定会运行的代码。
try:
print('try is operated')
print(1/0)
except:
print('error')
finally:
print('finally')
在实际的应用中,我们一般用try去捕捉异常,但异常发生时,我们需要了解抛出的异常的类型,以便去修正它。
在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:
print('try is operated')
print(1/0)
except ValueError:
print('error')
finally:
print('finally')
注意和上一个例子的比较,上一个例子中except后面没有跟着错误类型,所以不会抛出错误,代码会一直运行到结束。而这个例子中except后面有了错误类型,因而会抛出错误。 为错误加上详细信息,
try:
print('try is operated')
print(1/0)
except ValueError('0 is not'):
print('error')
finally:
print('finally')
有时候我们可以预先预料到某种错误的发生,此时可以用raise来抛出错误。
x = input('please input a number:')
if x != 5:
raise ValueError
为错误加上更多的信息:
x = input('please input a number:')
if x != 5:
raise ValueError('not my dream number')
在3.中我们用了if…raise…来抛出错误,如果利用assert…则不需要判断。也就是说 assert的语法格式:
assert expression
它的等价语句为:
if not expression:
raise AssertionError
x = input('please input a number:')
assert x == 5,ValueError('not my number')
需要注意的是,assert 后面的条件为假时才抛出错误,这是重点。