异常的概念

  • 程序在运行时,如果python解释器遇见一个错误,就会停止程序的运行,并且提示一些错误信息,这就是异常;
  • 程序遇见错误停止执行并且提示错误信息,这个动作我们称之为抛出(raise)异常;

异常有可能是我们没有按照代码规范而引起的;

但也有可能即使按照代码规范编写,也会出错,比如我们提示用户输入一个数字,然后int转译,但用户输入一个非数字,就会报错;

程序开发时,很难将所有情况都处理的面面俱到,通过异常捕获可以针对突发事件做集中的处理,从而保证程序的稳定性和健壮性;

捕获异常

简单的异常捕获

在程序开发中,如果对某些代码的执行不能确定是否会正确执行,我们可以增加try(尝试)来捕获异常;

捕获异常最简单的语法格式:

try:
尝试执行的代码
except:
出现错误的处理

try 尝试,下方编写要尝试代码,不确定是否能够正确执行的代码;

except 如果不是,下方编写尝试失败的代码;

简单异常捕获示例

try:
# 不能确定是否会正确执行的代码
num = int(input("请输入一个整数:"))
except:
# 处理出现错误之后代码
print("请确保你输入的是一个整数") print("-"*50) # 请输入一个整数:1
# -------------------------------------------------- # 请输入一个整数:a
# 请确保你输入的是一个整数
# --------------------------------------------------

错误类型捕获

在程序执行时,可能会遇到不同类型的异常,并且需要针对不同类型的异常,做出不同的响应,这个时候,就需要使用错误类型捕获了。

错误类型捕获语法如下:

try:
# 尝试执行的代码
pass
except 错误类型1:
# 针对错误类型1,对应的代码处理
pass
except (错误类型2,错误类型3):
# 针对错误类型2和3,对应的代码处理
pass
# 下面三句是后面的内容
except Exception as e:
print("未知异常:", e)

当python解释器抛出异常后,最后一行错误信息的第一个单词,就是错误类型,例如下面,错误信息就是 ZeroDivisionError;

ZeroDivisionError: division by zero

错误类型捕获代码演示

while 1:
try:
num = int(input("请输入一个整数:")) result = 8/num
print("8除以这个数字的结果是:", result)
break except ZeroDivisionError:
print("你输入的是一个0,不能被除,请重新输入")
continue except ValueError:
print("请确保你输入的是一个整数,请重新输入")
continue except Exception as e:
print("出错了:%s ,请重新输入", e)
continue # 请输入一个整数:0
# 你输入的是一个0,不能被除,请重新输入
# 请输入一个整数:a
# 请确保你输入的是一个整数,请重新输入
# 请输入一个整数:2
# 8除以这个数字的结果是: 4.0

捕获未知异常

在开发时,要预判到所有可能出现的错误,是很难的;

如果希望程序无论出现任何错误,都不会因为python解释器抛出异常而被终止,可以增加如下语句:

except Exception as e:
print("出错了:%s ,请重新输入", e)

捕获未知异常演示

while 1:
try:
num = int(input("请输入一个整数:")) result = 8/num
print("8除以这个数字的结果是:", result)
break except ValueError:
print("请确保你输入的是一个整数,请重新输入")
continue except Exception as e:
print("出错了:%s ,请重新输入", e)
continue # 请输入一个整数:a
# 请确保你输入的是一个整数,请重新输入
# 请输入一个整数:0
# 出错了:division by zero ,请重新输入
# 请输入一个整数:1
# 8除以这个数字的结果是: 8.0

异常捕获完整语法

在实际开发中,为了能够处理复杂的异常情况,完整的异常语法如下:

try:
# 尝试执行的代码
pass
except 错误类型1:
# 针对错误类型1,对应的代码处理
pass
except (错误类型2,错误类型3):
# 针对错误类型2和3,对应的代码处理
pass
except Exception as e:
print("未知异常:", e)
else:
# 没有异常才会执行的代码
pass
finally:
# 无论是否出现异常都会执行的代码
pass
  • else 是 只有在没有异常时才会执行的代码;
  • finally 是 无论是否出现异常都会执行的代码;

异常捕获完整语法示例

while 1:
try:
num = int(input("请输入一个整数:")) result = 8/num
print("8除以这个数字的结果是:", result) except ZeroDivisionError:
print("你输入的是一个0,不能被除,请重新输入")
continue except ValueError:
print("请确保你输入的是一个整数,请重新输入")
continue except Exception as e:
print("出错了:%s ,请重新输入" % e)
continue else:
print("代码正常执行")
break
finally:
print("无论是否出现异常都会执行的代码")

异常的传递

  • 异常的传递:当代码/方法执行出现异常,会将异常传递给函数/方法的调用一方
  • 如果传递到主程序,还没有处理异常,程序才会被终止;

提示:

  • 在开发中,可以给主程序增加异常处理
  • 而在主程序中调用其他的函数,只要出现异常,就会传递给主程序的异常捕获;
  • 这样就不需要在函数/方法中,增加大量的异常捕获,可以保证代码的整洁性;

异常传递处理示例

def demo1():
num = int(input("请输入一个整数:"))
return num def demo2():
return demo1() # 利用异常的传递性,在主程序捕获异常
try:
result = demo2()
print(result)
except ValueError:
print("请确保你输入的是一个整数")
except Exception as e:
print("出错了:%s " % e)

抛出(raise)异常

抛出异常应用场景

在程序中,除了代码出错解释器会抛出异常之外,还可以根据应用程序 特定业务需求 主动抛出异常

例如:注册时,如果用户输入的密码少于8位,抛出异常提醒长度不够;

注意:

当前函数,只提醒用户输入密码,如果密码长度不够,需要其他额外的函数进行异常处理;

因此可以抛出异常,由其他需要处理的函数捕获异常.

抛出异常

python中提供了一个Exception异常类;

在开发时,如果满足特定业务需求时,希望抛出异常,可以:

1.创建一个Exception类的对象
2.使用raise关键字抛出异常对象

主动抛出异常示例

def input_pwd():
pwd = input("请输入密码:") if len(pwd) >= 8:
return pwd
# 创建异常对象,可以使用错误信息字符串作为参数
short_pwd = Exception("密码长度小于8位")
# 主动抛出异常
raise short_pwd try:
password = input_pwd()
print(password) except Exception as e:
print("出错了:", e)

Python面向对象之异常的更多相关文章

  1. Python面向对象之异常捕获(一)-----抛出一个异常

    大部分的异常都继承自Exception这个类(而这个类有继承自BaseException这个类) 常见的异常 ValueError TypeError IndexError 抛出一个异常 下面这个类的 ...

  2. python 面向对象和类成员和异常处理

    python 面向对象 你把自己想象成一个上帝,你要创造一个星球,首先你要把它揉成一个个球,两个直径就能创造一个球 class star: '''名字(name),赤道直径(equatorial di ...

  3. python 面向对象进阶之内置方法

    一 isinstance(obj,cls)和issubclass(sub,super) 1.1,isinstance(obj,cls)检查是否obj是否是类 cls 的对象 class Foo(obj ...

  4. #4 Python面向对象(三)

    前言 前两节讲解了Python面向对象的思想和Python类中各种变量的含义以及区别.肯定有小伙伴会问,类初始化时是否可以传入参数?如果有多个类中含有共同的函数方法,是否可以重复利用?本节就带着这些问 ...

  5. python面向对象编程进阶

    python面向对象编程进阶 一.isinstance(obj,cls)和issubclass(sub,super) isinstance(obj,cls)检查是否obj是否是类 cls 的对象 1 ...

  6. Python学习笔记【第十一篇】:Python面向对象高级

    isinstance(obj,cls)和issubclass(sub,super) class Person(object): def __init__(self, name, age, sex, n ...

  7. Python面向对象-day07

    写在前面 上课第七天,打卡: 时间的高效利用: 前言: 今天egon老师补充了下 is 和 == 的区别,整理如下:Python中变量的属性以及判断方法 一.面向过程和面向对象 - 1.面向过程 核心 ...

  8. python 面向对象编程 之 反射

    1 什么是反射 反射的概念是由Smith在1982年首次提出的,主要是指程序可以访问.检测和修改它本身状态或行为的一种能力(自省).这一概念的提出很快引发了计算机科学领域关于应用反射性的研究.它首先被 ...

  9. Python面向对象补充以及异常处理

    面向对象相关内容 一.isinstance(obj, cls) 检查是否obj是否是类 cls 的对象 class Foo(object): pass obj = Foo() isinstance(o ...

随机推荐

  1. mac的日常使用总结

    目录 有一个github的仓库:(强烈推荐) 不推荐的但是可以试试的一些链接: # 关于mac book的使用教程 github简直是一个宝藏,发现好多各种好玩的东西, 爱了爱了, 开源一定是未来, ...

  2. SVG新手入门

    特点 矢量图 属性:形状的参数(都没有单位) 添加事件跟html一样 修改样式跟html一样 属性操作: setAttribute/getAttribute 图形 <svg width=&quo ...

  3. 浅谈欧拉函数 By cellur925

    1.某神犇Blog 学了三遍的 欧拉函数φ--DEADFISH7 2.我要做一些补充o(* ̄▽ ̄*)o $φ(1)=1$: 公式有两种形式,一种有太多除法,实际可能会慢些.通用 对于任意$n$> ...

  4. 题解报告:poj 2480 Longge's problem(欧拉函数)

    Description Longge is good at mathematics and he likes to think about hard mathematical problems whi ...

  5. Apache Kylin的架构特性

    不多说,直接上干货! http://kylin.apache.org/cn/ 可扩展的超快OLAP引擎,提供标准SQL查询接口 支持单机或集群部署,为减少在Hadoop上百亿规模数据查询延迟而设计: ...

  6. Python打开目录下所有文件

    用Python打开指定目录下所有文件,统计文件里特定的字段信息. 这里是先进入2017-02-25到2017-03-03目录,然后进入特定IP段目录下,最后打开文件进行统计 import os, gl ...

  7. canvas 平移&缩放

    1.平移 canvas其实只是一个包装器,真正起着重要作用的部分是2D渲染上下文,这才是我们真正绘制图形的地方. 然而2D渲染上下文是一种基于屏幕的标准绘制平台.它采用屏幕的笛卡尔坐标系统,以左上角( ...

  8. fetch和axios区别,proxy代理配置

    1.今天使用fetch调用接口时使用console.log(res.data)始终是undefined,使用anxios请求则可以成功请求到数据,非常奇怪,于是查了一圈,才搞明白是我自以为了,哎,浪费 ...

  9. docker最新版本以及docker-compose安装脚本

    docker最新版本以及docker-compose编排工具安装脚本 git clone https://github.com/luckman666/shell_scripts.git cd shel ...

  10. FragmentTabHost实现标签卡效果

    转载请注明原文链接:http://www.cnblogs.com/yanyojun/p/8099523.html 代码已上传到github:https://github.com/YanYoJun/Fr ...