目录
try except (异常捕获)
1、异常处理流程图:
2、常见异常
3、处理单个异常
4、处理多个异常
5、Exception异常
6、else作用
7、finnally作用
8、自定义异常
触发自定义异常:
9,异常实例
10,异常的结构
11,主动触发异常
断言
try except (异常捕获)
当程序出错了,但是我们又不想让用户看到这个错误,而且我在写程序的时候已经预料到了它可以出现这样的错误,出现这样的错误代表着什么,我们可以提前捕获这些个错误
1、异常处理流程图:

2、常见异常
1 2 3 4 5 6 7 8 9 10 11 12 13 | AttributeError 试图访问一个对象没有的树形,比如foo.x,但是foo没有属性x IOError 输入 / 输出异常;基本上是无法打开文件 ImportError 无法引入模块或包;基本上是路径问题或名称错误 IndentationError 语法错误(的子类) ;代码没有正确对齐 IndexError 下标索引超出序列边界,比如当x只有三个元素,却试图访问x[ 5 ] KeyError 试图访问字典里不存在的键 KeyboardInterrupt Ctrl + C被按下 NameError 使用一个还未被赋予对象的变量 SyntaxError Python代码非法,代码不能编译(个人认为这是语法错误,写错了) TypeError 传入对象类型与要求的不符合 UnboundLocalError 试图访问一个还未被设置的局部变量,基本上是由于另有一个同名的全局变量,导致你以为正在访问它 ValueError 传入一个调用者不期望的值,即使值的类型是正确 |
3、处理单个异常
语法如下:
1 2 3 4 | try : code #处理的语句 except Error1 as e: #遇到Error1执行下面的语句,在python2中写成except Error1,e print (e) |
代码如下:
1 2 3 4 5 6 7 8 | name = [ 1 , 2 , 3 ] try : name[ 3 ] #不存在3这个下标值 except IndexError as e: #抓取 IndexError 这个异常 print (e) #e是错误的详细信息 #输出 list index out of range |
4、处理多个异常
①写多个except,语法如下:
1 2 3 4 5 6 | try : code except Error1 as e: #处理Error1异常 print (e) except Error2 as e: #处理Error2异常 print (e) |
代码如下:
1 2 3 4 5 6 7 8 9 10 11 12 | name = [ 1 , 2 , 3 ] data = { "a" : "b" } try : data[ "c" ] #这边已经出现异常KeyError ,所以直接跳出code,跳到KeyError 下去处理 name[ 3 ] except IndexError as e: print (e) except KeyError as e: print (e) #输出 'c' |
②写1个except,语法如下:
1 2 3 4 | try : code except (Error1,Error2,...) as e: print (e) |
代码如下:
1 2 3 4 5 6 7 8 | try : data[ "c" ] name[ 3 ] except (IndexError,KeyError) as e: print (e) #输出 'c' |
注:第二种写法的用处:括号里面的所有错误,不管出现里面任何一种错误都用统一的处理方法。
5、Exception异常
语法如下:
1 2 3 4 5 6 | try : code except (Error1,Error2,...) as e: print (e) except Exception as e: #用Exception表示一下子抓住所有异常,这个一般情况下建议在异常最后面用,用在最后抓未知的异常 print (e) |
代码如下:
1 2 3 4 5 6 7 8 9 | try : open ( "qigao.text" , "r" ,encoding = "utf-8" ) except (IndexError,KeyError) as e: #没有IndexError,KeyError这两个异常 print (e) except Exception as e: #只能通过这个异常处理,Exception 抓住所有的异常 print (e) #输出 [Errno 2 ] No such file or directory: 'qigao.text' |
6、else作用
作用:没有异常,则走else部分的逻辑代码
1 2 3 4 5 6 7 8 9 10 11 12 | try : print ( "qigao,handson" ) #代码没有异常 except (IndexError,KeyError) as e: print (e) except Exception as e: print (e) else : #没有异常出错,走else的逻辑代码 print ( "没有异常" ) #输出 qigao,handson 没有异常 |
7、finnally作用
作用:不管有没有错误,都会执行finnally中的代码
语法如下:
1 2 3 4 5 6 7 8 9 10 | try : code except (Error1,Error2,...) as e: print (e) except Exception as e: print (e) else : print ( "没有错误,执行" ) finnally: print ( "不管有没有错,都执行finnally" ) |
①没有异常情况
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | try : print ( "qigao,handson" ) #没有异常 except (IndexError,KeyError) as e: print (e) except Exception as e: print (e) else : print ( "没有异常" ) finally : print ( "不管有没有错,都这行finnally" ) #输出 qigao,handson 没有异常 不管有没有错,都这行finnally #没有报错,执行finnally |
②出现异常情况
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | try : data = { "a" : "b" } data[ "c" ] #data字典中没有'c'这个key值 except (IndexError,KeyError) as e: print (e) except Exception as e: print (e) else : print ( "没有异常" ) finally : print ( "不管有没有错,都这行finnally" ) #输出 'c' 不管有没有错,都这行finnally #出错了也执行了finnally语句 |
8、自定义异常
1 2 3 4 5 6 7 | class GaoError(Exception): #定义一个异常类,继承Exception def __init__( self ,message): self .message = message def __str__( self ): return self .message #给对象取一个名 |
触发自定义异常:
1 2 3 4 5 6 7 | try : raise GaoError( "数据库连接不上了" ) #触发自定义异常,GaoError("数据库连接不上了")这个对象 except GaoError as e: print (e) #输出 数据库连接不上了 |
自定义使用总结:
- 数据库连接不上的信息
- 权限问题,解析是没有权限了,给出异常提示
- 业务逻辑的错误
9,异常实例
#IndexError
dic = ["wupeiqi", 'alex']
try:
dic[10]
except IndexError, e:
print e
#KeyError
dic = {'k1':'v1'}
try:
dic['k20']
except KeyError, e:
print e
#ValueError
s1 = 'hello'
try:
int(s1)
except ValueError, e:
print e
10,异常的结构
完整的基本结构如下
try:
# 主代码块
pass
except KeyError as e:
# 异常时,执行该块
pass
else:
# 主代码块执行完,执行该块
pass
finally:
# 无论异常与否,最终执行该块
pass
11,主动触发异常
try:
raise Exception('错误了。。。')
except Exception as e:
print e
断言
断言被用作你接下来的程序执行,如果后面程序依赖于前面的程序,后面的程序有很重要,就是后面的程序执行肯定不能出错,所以在执行之前要做检查工作。
1、断言assert
1 2 3 4 5 6 7 8 9 10 11 12 13 | class C( object ): def __init__( self ): self .name = "AAAAA" c_obj = C() assert c_obj.name = = "AAAAA" #断言 print ( "没有错误继续..." ) #输出 没有错误继续.. |
2、断言不符合
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | class C( object ): def __init__( self ): self .name = "AAAAA" c_obj = C() assert c_obj.name = = "BBBBB" #断言出字符串不匹配 print ( "没有错误继续..." ) #输出 Traceback (most recent call last): File "E:/PycharmProjects/pytest/day7/断言.py" , line 10 , in <module> assert c_obj.name = = "BBBBB AssertionError #报断言异常错误 |
3、其实也可以使用if解决这个问题,不过相比之下断言assert更优雅一些,减少代码量
1 2 3 4 5 6 7 8 9 10 11 | class C( object ): def __init__( self ): self .name = "zhangqigao" c_obj = C() if c_obj.name = = "gaogao" : print ( "有错误...." ) else : print ( "没有错误继续..." ) |
部分转载https://www.cnblogs.com/whatisfantasy/p/6038360.html
以及http://www.cnblogs.com/Keep-Ambition/p/7306074.html