断言
断言是编程术语,表示为一些布尔表达式,程序员相信在程序中的某个特定点该表达式值为真.
在python中使用assert关键字,后面是一个表达式,当表达式值为真时会继续执行,否则抛出AssertionError
# test1.py assert 1==2 print('hello') # 抛出异常AssertionError # test1.py assert 1==1 print('hello') # 打印hello
异常
异常就是程序运行时(逻辑错误)发生错误的信号,错误范围两种-语法错误和逻辑错误
语法错误:
#语法错误示范一 if #语法错误示范二 def test: pass #语法错误示范三 print(haha
逻辑错误
#用户输入不完整(比如输入为空)或者输入非法(输入不是数字) num=input(">>: ") int(num) #无法完成计算 res1=1/0 res2=1+'str'
如果程序运行的过程中发现了错误就会抛出异常
常见异常:
AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x IOError 输入/输出异常;基本上是无法打开文件 ImportError 无法引入模块或包;基本上是路径问题或名称错误 IndentationError 语法错误(的子类) ;代码没有正确对齐 IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[5] KeyError 试图访问字典里不存在的键 KeyboardInterrupt Ctrl+C被按下 NameError 使用一个还未被赋予对象的变量 SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了) TypeError 传入对象类型与要求的不符合 UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量, 导致你以为正在访问它 ValueError 传入一个调用者不期望的值,即使值的类型是正确的
更多异常
ArithmeticError AssertionError AttributeError BaseException BufferError BytesWarning DeprecationWarning EnvironmentError EOFError Exception FloatingPointError FutureWarning GeneratorExit ImportError ImportWarning IndentationError IndexError IOError KeyboardInterrupt KeyError LookupError MemoryError NameError NotImplementedError OSError OverflowError PendingDeprecationWarning ReferenceError RuntimeError RuntimeWarning StandardError StopIteration SyntaxError SyntaxWarning SystemError SystemExit TabError TypeError UnboundLocalError UnicodeDecodeError UnicodeEncodeError UnicodeError UnicodeTranslateError UnicodeWarning UserWarning ValueError Warning ZeroDivisionError
异常处理
异常发生后,异常代码之后的代码就不执行了
python解释器检测到错误,触发异常(也允许程序员自己触发异常)
程序员编写特定的代码,专门用来捕捉这个异常(这段代码与程序逻辑无关,与异常处理有关)
如果捕捉成功则进入另外一个处理分支,执行你为其定制的逻辑,使程序不会崩溃,这就是异常处理
为什么要进行异常处理
python解析器去执行程序,检测到了一个错误时,触发异常,异常触发后且没被处理的情况下,程序就在当前异常处终止,后面的代码不会运行,使用异常处理时,后面的代码就会运行
如何进行异常处理
首先须知,异常是由程序的错误引起的,语法上的错误跟异常处理无关,必须在程序运行前就修正
异常处理的语法
基本语法:
#try: # 被检测的代码块 #except 异常类型: # try中一旦检测到异常,就执行这个位置的逻辑 try: a except NameError: print('NameError') #执行结果NameError try: a except NameError as e: print('NameError') #执行结果 NameError name 'a' is not defined #使用as可以得到错误的值
异常类只能用来处理指定的异常情况,如果非指定异常则无法处理。
# 未捕获到异常,程序直接报错 try: a except IndexError : print('NameError') #执行结果,错误类型是NameError而不是IndexError NameError: name 'a' is not defined
多分支
s1 = 'hello' try: int(s1) except IndexError as e: print(e) except KeyError as e: print(e) except ValueError as e: print(e) #由上至下运行,先找到能处理的error类型,就执行该except中的内容
万能异常
# 万能异常能够处理所有的异常,但是不要乱用。 # 对于已经意料到的错误,应使用指定的异常进行处理 # 万能异常使用来处理预料不到的异常类型的 try: num = int(input('请输入序号 : ')) except Exception as e: print('异常啦') # 万能异常应放在所有的except后
try-except-else语法
else后面跟的是try中代码没有发生异常运行的内容
try: num = int(input('请输入序号 : ')) except Exception as e: print('异常啦') else: #如果try中的代码不会发生异常,就走这个else中的内容 print('没毛病') print("-----") #运行结果 #请输入序号 : 1 #没毛病 #----- #异常 #请输入序号 : a #异常啦 #-----
try-except-findlly语法
findlly后面的内容是无论异不异常都执行的
try: num = int(input('请输入序号 : ')) except Exception as e: print('异常啦') else: #如果try中的代码不会发生异常,就走这个else中的内容 print('没毛病') finally: print('不管异常不异常我都走这个') #执行结果 #请输入序号 : 1 #没毛病 #不管异常不异常我都走这个 #异常 #请输入序号 : a #异常啦 #不管异常不异常我都走这个
findlly的用途可以用在文件的关闭,或者数据库连接的关闭
获取异常的堆栈信息
通过打印as语法得到的异常对象我们可以得到错误信息, 但是得不到具体是哪里的错误, 这是我们可以通过tarceback得到这些信息
import traceback print(traceback.print_exc())
主动抛出异常
主动抛出异常是检查代码逻辑或者说是否可以在某些特殊情况下正常工作的一种方法。
python中使用raise来主动抛出一个异常(异常类的实例)
try: raise TypeError('类型错误') except Exception as e: print(e) #类型错误
自定义异常类
1.定义一个异常类,该类从Exception类中继承
2.在try中使用raise语句引发异常
3.except捕获异常,并执行相关命令
#_*_coding=UTF-8_*_ #使用自定义异常类实现指定输入字符串长度 #自定义异常类 class SomeCustomError(Exception): def __init__(self,str_length): super(SomeCustomError,self).__init__() self.str_length = str_length #使用自定义异常 length = input("输入指定输入字符串长度范围: ") while True: try: s = raw_input("输入一行字符串: ") #输入字符串长度超过指定长度范围,引发异常 if (length < len(s)): raise SomeCustomError(length) except SomeCustomError,x: print("捕获自定义异常") print("输入字符串重读应该小于%d,请重新输入!" % x.str_length) else: print("输入字符串为%s" % s) break