python跳过异常_python的异常处理

在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!"

上述代码输出结果如下。该代码既能够通过

math?formula=e输出产生异常的原因,同时也能够使程序继续执行,输出“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中的代码。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值