python的异常处理及异常类定义

python的异常处理语法和大多数语言相似:

try:

try块的语句...

except exceptiontype1 as var:#使用as语句获得本次捕获到的异常的实例var

  except块语句...

except exceptiontype2 as var:

  except块语句...

except:

  except块语句...

else:

  else块语句...

finally:

  finally块语句...

执行的流程分两类:

1.try->若有异常发生->except->finally
2.try->若无异常发生->else->finally

其中try块执行了可能抛出异常的语句,except块负责处理抛出的异常,处理的尝试顺序与多个except块的编写顺序一致,当尝试发现第一个异常类型匹配的except块时就进入该块内执行该except块的语句,最后一个不指定异常类型的except:  块匹配任何类型的异常(由于所有异常都继承自Exception类所有except Exception:与不指定异常类型效果一致)。

except块至少要有一个,可以使用pass语句如

except:

  pass

表示“抓到”异常后不进行任何处理。

finally类是可选的块,如前面的流程所示,无论是否有异常抛出,只要finally块存在就会被最终执行(该块中的语句一般用于关闭打开的资源,比如在try块中打开的磁盘文件)

此外,python中提供另一种简单的写法:with...as...方式

with open(‘abc.txt‘, ‘r‘) as f:

  f语句块....

上面的f就是打开的文件对象,而采用with..as..方式会在执行完f语句块后自动关闭打开的文件资源,而不用自己写finally语句块。

至于背后的机理,实际上面的with...as...语句在进入f语句块之前调用open对象(注意python中函数也是对象,具有__call__方法的对象都可以当函数用)

的__enter__方法,该方法的返回值赋值给as后面的f,再在执行完f语句块后调用open对象的__exit__方法,而open对象作为python的内置对象默认的__enter__方法返回文件对象而__exit__方法刚好关闭了打开的文件资源从而使我们用起来感觉像方便版的try ,finally。

了解了上面的内容后,下面定义我们自己的新的异常类(这在实际开发过程中非常有用):

class myerr(Exception):
    def __init__(self,err):
        Exception.__init__(self)
        self.err=err
try:
    raise myerr(‘myexception‘)
except myerr as var :
    print(var.err)

定义自己的异常类一般都继承自Exception类,初始化时同时使用Exception类的__init__方法,此外,可以通过添加一个err属性用于存放错误信息,方便在后续的异常处理中可以根据错误信息的不同来进行不同的处理。

引发自己定义的异常的语法是raise exceptiontype(arg...),直接生成该异常类的一个实例(实例化时需要的参数自行提供)并抛出该异常

在捕获异常时使用except exceptiontype as var的语法获取异常实例var,从而可以在后续的处理中访问该异常实例的属性。

如上面代码的输出为:

myexception

 

__call__方法的对象都可以当函数用
-->

python的异常处理及异常类定义

时间: 2024-10-05 23:13:31

python的异常处理及异常类定义的相关文章

python所有的标准异常类:

python所有的标准异常类: 异常名称 描述 BaseException 所有异常的基类 SystemExit 解释器请求退出 KeyboardInterrupt 用户中断执行(通常是输入^C) Exception 常规错误的基类 StopIteration 迭代器没有更多的值 GeneratorExit 生成器(generator)发生异常来通知退出 SystemExit Python 解释器请求退出 StandardError 所有的内建标准异常的基类 ArithmeticError 所有

课堂动手动脑验证以及自定义异常类实现对异常处理——java异常类

异常(exception):发生在程序执行期间,表明出现了一个非法运行的情况.许多JDK中的方法在检测到非法情况时,都会抛出一个异常对象.例如:数组越界和被0除. 代码验证: package test; import javax.swing.*; class AboutException { public static void main(String[] a) { int i=1, j=0, k; try { k = i/j; // Causes division-by-zero except

python所有的标准异常类

  异常名称 描述 BaseException 所有异常的基类 SystemExit 解释器请求退出 KeyboardInterrupt 用户中断执行(通常是输入^C) Exception 常规错误的基类 StopIteration 迭代器没有更多的值 GeneratorExit 生成器(generator)发生异常来通知退出 SystemExit Python 解释器请求退出 StandardError 所有的内建标准异常的基类 ArithmeticError 所有数值计算错误的基类 Floa

Python(2.7.6) 异常类的继承关系

BaseException +-- SystemExit +-- KeyboardInterrupt +-- GeneratorExit +-- Exception +-- StopIteration +-- StandardError | +-- BufferError | +-- ArithmeticError | | +-- FloatingPointError | | +-- OverflowError | | +-- ZeroDivisionError | +-- AssertionE

(Python)异常处理try...except、raise

转载自https://www.cnblogs.com/Lival/p/6203111.html (Python)异常处理try...except.raise 一.try...except 有时候我们写程序的时候,会出现一些错误或异常,导致程序终止.例如,做除法时,除数为0,会引起一个ZeroDivisionError 例子: ? 1 2 3 4 a=10 b=0 c=a/b print "done" 运行结果: Traceback (most recent call last): Fi

python中不同的异常类型,如何进行异常处理?

一.错误与异常 程序中难免会出现错误,而错误分为两种 1.语法错误:(这种错误,根本过不了python解释器的语法检测,必须在程序执行前就改正) 2.逻辑错误:(逻辑错误),比如用户输入的不合适等一系列错误 那什么是异常呢? 异常就是程序运行时发生错误的信号,在python中,错误触发的异常如下.异常发生之后,异常之后的代码就不执行了 异常种类:在python中不同的异常可以用不同的类型(python中统一了类与类型,类型即类)去标识, 不同的类对象标识不同的异常,一个异常标识一种错误 常见的异

C++异常类的定义和使用以及我对异常类的理解

异常类的作用就是在执行我们自己的某个功能函数出现意外情况时,为了方便查找错误出处,可以在意外发生时抛出异常(1).首先定义自己的异常类 可以直接定义也可以从标准异常类派生    class  CEGUIEXPORT Exception    {    public:        virtual ~Exception(void);        const String& getMessage(void) const  {return d_message;}        const Strin

Python笔记——类定义

Python笔记——类定义 一.类定义: class <类名>: <语句> 类实例化后,可以使用其属性,实际上,创建一个类之后,可以通过类名访问其属性 如果直接使用类名修改其属性,那么将直接影响到已经实例化的对象 类的私有属性: __private_attrs  两个下划线开头,声明该属性为私有,不能在类地外部被使用或直接访问 在类内部的方法中使用时 self.__private_attrs 类的方法 在类地内部,使用def关键字可以为类定义一个方法,与一般函数定义不同,类方法必须

C#高级编程八十二天----用户自己定义异常类

用户自己定义异常类 前面已经说了不少关于异常的问题了,如今来给大家说一下自己定义异常时咋个回事以及咋样. ? 为啥会出现自己定义异常类呢? 用用脚趾头想想也明确,是为了定义咱们自己的异常,自己定义异常类继承自ApplicationException? 首先异常(Exception)分为两大类,一个是提前定义的异常类,后者是用户自己定义异常类时须要继承的类. 案例: ? using?System; using?System.Collections.Generic; using?System.Lin