Pyhton:异常

python中的异常种类非常多,每一个异常专门用于某一项异常。主要是为了代码调试和程序运行

语法:

try:
    expression
except:
    expression #如果try中的代码有异常就执行这段代码
else:
    expression #如果try中的代码没有出现异常就执行这段代码
finally:
    expression #无论try中代码是否有异常,都必须执行这段代码

常见的异常

AttributeError 试图访问一个对象没有的属性
IOError 输入/输出异常;基本上是无法打开文件
ImportError 无法引入模块或包
IndentationError 语法错误(的子类) ;代码没有正确对齐,这个错误无法抓取到
IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5]
KeyError 试图访问字典里不存在的键
KeyboardInterrupt Ctrl+C被按下
NameError 使用一个还未被赋予对象的变量
SyntaxError Python代码非法,无法抓取
TypeError 传入对象类型与要求的不符合
UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,导致你以为正在访问它
ValueError 传入一个程序不期望的值,即使值的类型是正确的

示例

捕获异常

user=raw_input("input number:")#输入asd,就会出现异常
print int(user)  
ValueError: invalid literal for int() with base 10: 'asd'

接下来我们捕获异常

while True:
    try:
        user=raw_input("input number:")
        print int(user) #到这出现异常,那么这段代码后的代码将不会执行,直接执行excpt语句,然后继续循环
        if int(user)==1:
            break
    except ValueError as e:
        print "Value Error"

演示效果,捕获到了这个异常

input number:ad
Value Error
input number:asd
Value Error
input number:1
1
while True:
    try:
        a=[1,23,5,6]
        user=raw_input("input number:")  #输入6时
        print int(user)
        print a[int(user)]
    except ValueError as e:
        print "Value Error"

异常出现

IndexError: list index out of range

这时我们捕获这个IndexError这个异常

while True:
    try:
        a=[1,23,5,6]
        user=raw_input("input number:")
        print int(user)
        print a[int(user)]
        break
    except ValueError as e:
        print "Value Error"
    except IndexError as e:
        print "Index Error"

结果:

input number:ad
Value Error
input number:123
123
Index Error
input number:1
1
23

当然我们也可以使用Exception来捕获所有类型的错误,但是这不利于我们对代码的调试

while True:
    try:
        a=[1,23,5,6]
        user=raw_input("input number:")
        print int(user)
        print a[int(user)]
        break
    except Exception as e:
        print e

finally示例

while True:
    try:
        a=[1,23,5,6]
        user=raw_input("input number:")
        print a[int(user)]
        break
    except Exception as e:
        print e
    finally:
        print "bingo!!"

结果:

input number:123
list index out of range
bingo!!
input number:as
invalid literal for int() with base 10: 'as'
bingo!!
input number:1
23
bingo!!

无论try中的语句是否有错,都会执行finally中的代码

else示例:

while True:
    try:
        a=[1,23,5,6]
        user=raw_input("input number:")
        print a[int(user)]

    except Exception as e:
        print e
    else:
        print"ok!!"
        break

结果:

input number:123
list index out of range
input number:asd
invalid literal for int() with base 10: 'asd'
input number:1
23
ok!!

主动触发异常

try:
    raise Exception('错了')  #主动触发异常
except Exception as e:
    print e

结果

错了

自定义异常

异常类

class Exception(BaseException):
    """ Common base class for all non-exit exceptions. """
    def __init__(self, *args, **kwargs): # real signature unknown
        pass

    @staticmethod # known case of __new__
    def __new__(S, *more): # real signature unknown; restored from __doc__
        """ T.__new__(S, ...) -> a new object with type S, a subtype of T """
        pass
class MyException(Exception):  #继承Exception类
    #重写这个构造器
    def __init__(self,message):
        self.mes=message

    def __str__(self): #这个特殊方法与print有关,有他就可以print实例了,结果就是返回值
        return self.mes


try:
    raise MyException('my exception')
except MyException as e:
    print e

结果:
my exception

断言

语法

assert expression [,argument]

如果断言成功就不采取任何措施,否则就触发AssertError的异常

>>> assert 1==1
>>> assert 1==2
Traceback (most recent call last):
  File "<input>", line 1, in <module>
AssertionError

>>> assert len('my list')<12
>>> assert len('my list')<5
Traceback (most recent call last):
  File "<input>", line 1, in <module>
AssertionError

>>> a=1
>>> assert isinstance(a,int)
>>> assert isinstance(a,float)
Traceback (most recent call last):
  File "<input>", line 1, in <module>
AssertionError

转载于:https://www.cnblogs.com/cmustard/p/6769923.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值