python中的所有异常都是基类什么的成员_《转》Python学习(16)-python异常

一、什么是错误,什么是异常,它们两者区别

这里解释如下:个人觉得很通俗易懂

错误是指在执行代码过程中发生的事件,它中断或干扰代码的正常流程并创建异常对象。当错误中断流程时,该程序将尝试寻找异常处理程序(一段告诉程序如何对错误做出响应的代码),以帮助程序恢复流程。换句话说,错误是一个事件,而异常是该事件创建的对象。

当使用短语“产生异常”时,表示存在问题的方法发生错误,并创建异常对象(包含该错误的信息及发生的时间和位置)来响应该错误。导致出现错误和随后异常的因素包括用户错误、资源失败和编程逻辑失败。这些错误与代码实现特定任务的方法有关,而与该任务的目的无关。

如果不进行异常处理,即不对错误做出响应,程序的健壮性就会大打折扣,甚至无法保证正常运行,所以必须要进行异常处理。

原文:http:[email protected]/blog/static/279729562008719384580/

Python的异常处理能力是很强大的,可向用户准确反馈出错信息。在Python中,异常也是对象,可对它进行操作。所有异常都是基类

Exception的成员。所有异常都从基类Exception继承,而且都在exceptions模块中定义。Python自动将所有异常名称放在内建

命名空间中,所以程序不必导入exceptions模块即可使用异常。一旦引发而且没有捕捉SystemExit异常,程序执行就会终止。如果交互式会话

遇到一个未被捕捉的SystemExit异常,会话就会终止。

Python采用的是”尝试(try)块“、和”捕获(catch)块“。

二、Python中的异常

1、NameError:尝试访问一个未声明的变量

>>>foo

Traceback (most recent call last):

File "", line 1, in foo

NameError: name ‘foo‘ is not defined

如果请求的名字没有在任何名称空间里找到,则产生一个NameError异常。

2、ZeroDivisionError:除数为0

>>> 1/0

Traceback (most recent call last):

File "", line 1, in

1/0

ZeroDivisionError: integer division or modulo by zero

3、SyntaxError:Python解释器语法错误

>>> forSyntaxError: invalid syntax

>>>

SyntaxError异常是唯一一个不是在程序执行时发生的异常,代表一个不正常的结构,一般在编译时发生。

注意:Python是解释型非编译型,这里说的编译是字节编译。

4、IndexError:超出索引( out of range)

>>> lis =[]

>>>lis[0]

Traceback (most recent call last):

File "", line 1, in lis[0]

IndexError: list index out of range

5、KeyError:请求一个不存在的字典关键字

>>> dic = {‘name‘:‘BeginMan‘}

>>> dic[‘name‘]

‘BeginMan‘

>>> dic[‘age‘]

Traceback (most recent call last):

File "", line 1, in dic[‘age‘]

KeyError: ‘age‘

>>>

6、IOError:输入输出错误

>>> f = open(‘s.txt‘,‘r‘)

Traceback (most recent call last):

File "", line 1, in f = open(‘s.txt‘,‘r‘)

IOError: [Errno 2] No such file or directory: ‘s.txt‘

7、AttributeError:尝试访问未知的属性

>>> classmyClass(object):

pass

>>> myIn =myClass()

>>>myIn.bar

Traceback (most recent call last):

File "", line 1, in myIn.bar

AttributeError: ‘myClass‘ object has no attribute ‘bar‘

>>>

8、ValueError:传给函数的参数类型不正确,比如给int()函数传入字符串形

三、异常处理

try-except/try-finally只選其一,可以一个try多个except;但只能一个try,一个finally

try-except-finally组合

try:

s = 1/0

#except Exception,e:

exceptZeroDivisionError, e:

print ‘Error:%s‘ %e

finally:

print ‘ok‘

断言assert:

try:

assert 1 == 2,‘1 is not equal 2‘

exceptException,e:

print ‘%s:%s‘ %(e.__class__.__name__,e)

#输出:AssertionError:1 is not equal 2

注意:

如果上面的with代码块没有使用from __future__ import with_statement, 代码将会报错, 提示你这个功能在2.6中实现.

Warning: ‘with‘ will become a reserved keyword in Python 2.6

原文:http://www.cnblogs.com/nolonely/p/6641528.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Python的抽象基类(Abstract Base Class,简称ABC)是一种特殊的类,它定义了一组抽象方法,这些方法必须在子类实现。ABC的一个主要用途是为了检查子类是否符合某个接口的规范。 在ABC,可以使用`__subclasshook__`方法来判断一个类是否是该ABC的虚拟子类。具体来说,如果一个类没有直接继承该ABC,但是它的基类有`__subclasshook__`方法,而且该方法返回True,则该类就被视为该ABC的虚拟子类。 下面是一个例子,我们定义了一个ABC `MyABC`,其定义了一个抽象方法`my_method`。然后定义了一个普通类`MyClass`,它继承自`object`,并且实现了`my_method`方法。最后,我们在`MyClass`定义了`__subclasshook__`方法,它判断一个类是否实现了`my_method`方法。 ```python from abc import ABC, abstractmethod class MyABC(ABC): @abstractmethod def my_method(self): pass class MyClass(object): def my_method(self): print("MyClass.my_method() is called") @classmethod def __subclasshook__(cls, C): if cls is MyABC: if hasattr(C, 'my_method'): return True return NotImplemented print(issubclass(MyClass, MyABC)) # True ``` 在上面的代码,我们使用`issubclass`函数来检查`MyClass`是否是`MyABC`的子类。由于`MyClass`实现了`my_method`方法,而且定义了`__subclasshook__`方法,因此`issubclass(MyClass, MyABC)`返回True。 接下来我们实现一个自己的虚拟子类。我们定义一个普通类`MyClass2`,它没有直接继承自`MyABC`,但是它的基类定义了`__subclasshook__`方法,该方法判断一个类是否实现了`my_method`方法。然后我们通过`register`方法将`MyClass2`注册为`MyABC`的虚拟子类。 ```python class MyClass2(object): def my_method(self): print("MyClass2.my_method() is called") @classmethod def __subclasshook__(cls, C): if cls is MyABC: if hasattr(C, 'my_method'): return True return NotImplemented MyABC.register(MyClass2) print(issubclass(MyClass2, MyABC)) # True ``` 在上面的代码,我们使用`register`方法将`MyClass2`注册为`MyABC`的虚拟子类。然后我们再次使用`issubclass`函数来检查`MyClass2`是否是`MyABC`的子类。由于`MyClass2`实现了`my_method`方法,并且已经被注册为`MyABC`的虚拟子类,因此`issubclass(MyClass2, MyABC)`返回True。 总之,`__subclasshook__`方法是ABC的一个重要方法,它可以让我们方便地判断一个类是否符合某个接口的规范。同时,我们也可以通过`register`方法将一个普通类注册为ABC的虚拟子类。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值