day27

面向对象的总结

异常处理

错误的分类
  • 语法错误
if

if 2>1
print(222) dic = {"name"; "alex"}
  • 逻辑错误
num = int(input("请输入数字"))

dic = {"name": "海狗", "age": 18}
dic["hobby"]
什么是异常?

代码发生异常错误之后,你的程序就中断了

异常处理?

当代码出现异常时,我通过某种方式不让你的程序中断,合理的“跳”过去,异常处理

为什么要有异常处理?
  • 用户体验良好
  • 使你的代码更有健壮性,容错性
异常处理的两种方式
  • 利用if只能处理简单的异常,如果异常需要考虑的方面比较多,不适合
  • 利用try的方式进行异常处理
try的尝试
try:
num = int(input("请输入序号")) # 出现ValueError错误之后,直接跳转到except语句
print(111)
except ValueError:
print(666) try:
dic = {"name": "嘉欣"}
print(dic["age"])
num = int(input("请输入序号")) # 出现ValueError错误之后,直接跳转到except语句
print(111)
except ValueError:
print(666) # 报错
结构1:单分支
try:
num = int(input("请输入序号")) # 出现ValueError错误之后,直接跳转到except语句
dic = {"name": "嘉欣"}
print(dic["age"])
print(111)
except ValueError:
print(666)
结构2:多分支
try:
num = int(input("请输入序号")) # 出现ValueError错误之后,直接跳转到except语句
dic = {"name": "嘉欣"}
print(dic["age"])
l1 = [1,2]
print(l1[100])
print(111)
except ValueError:
print("输入的有非数字元素")
except KeyError:
print("没有此键")
except IndexError:
print("没有此下表")
结构3:万能异常

万能异常:处理所有python识别的异常

try:
dic = {"name": "嘉欣"}
print(dic["age"])
l1 = [1,2]
print(l1[100])
print(111)
except Exception as e:
print(e)
print(666)
什么时候用万能异常?

如果你对错误信息不关心,只是想要派出错误让程序继续运行,用万能异常

什么时候用多分支?

如果你对错误信息要进行明确的分流,让你的程序多元化开发,则使用多分支

# 之前的写法:
# num = input("输入序号")
# if num.isdecimal():
# num = int(num)
# if 0 < num < 5:
# if num == 1:
# pass # func()
# else:
# print("请输入数字") def func():
pass def func1():
pass dic = {
1: func,
2: func1
}
try:
num = int(input("请输入序号"))
dic[num]()
except ValueError:
print("请输入数字")
except KeyError:
print("请输入范围内的序号")
结构4:多分支+万能异常
def func():
pass def func1():
pass dic = {
1: func,
2: func1
}
try:
num = int(input("请输入序号"))
dic[num]()
except ValueError:
print("请输入数字")
except KeyError:
print("请输入范围内的序号")
except Exception:
print("程序出现意料之外的错误...")
结构5: try else finally

except 必须依赖于try,else必须依赖于except和try

finally只是依赖于try

try:
dic = {"name": "嘉欣"}
print(dic["age"])
l1 = [1,2]
print(l1[100])
print(111)
except KeyError:
print("没有此键")
except IndexError:
print("没有此下标")
else:
print("如果没有出现异常则执行这里")
finally:
print("finally 666")
  • finally:在异常出现之前,执行finally语句
try:
dic = {'name': '嘉欣'}
print(dic['age'])
l1 = [1, 2]
print(l1[100])
# except KeyError:
# print('没有此键')
# except IndexError:
# print('没有此下标')
# except IndexError:
# pass
finally:
print('finally 666')
  • finally用途

用在 关闭数据库链接,文件句柄关闭,数据保存等

# with open('test1',encoding='utf-8',mode='r+') as f1:
# try:
# for i in f1:
# print(i)
# if ....:
# finally:
#
# f1.close() # 在return结束函数之前,执行finally代码.
# def func():
# try:
# print(111)
# return 666
# finally:
# print(222)
# print(func())
结构6:主动触发异常
raise ValueError("出现了value错误")
结构7

断言:展现出一种强硬的态度

# assert 条件
name = "alex"
n1 = input("请输入:")
assert name == n1
print(111)
print(222)
结构8:自定义异常

python中给你提供的错误类型很多,但不是全部的错误

class LiYeError(BaseException):
def __init__(self, msg):
self.msg = msg def __str__(self):
return self.msg try:
# 三行
raise LiYeError('socket.connent.....')
except LiYeError as e: # e = LiYeError("类型错误)
print(e)

day27——面向对象的总结、异常处理的更多相关文章

  1. 简学Python第六章__class面向对象编程与异常处理

    Python第六章__class面向对象编程与异常处理 欢迎加入Linux_Python学习群  群号:478616847 目录: 面向对象的程序设计 类和对象 封装 继承与派生 多态与多态性 特性p ...

  2. day27 面向对象

    day27 面向对象 目录 day27 面向对象 一.面相对象介绍 1 什么是对象 2 类于对象 二.实现面向对象编程 1 先定义类 2 属性访问 2.1 调用dict方法 2.2 类.属性 3 调用 ...

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

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

  4. Python3基础(6)面向对象编程、异常处理

    ---------------个人学习笔记--------------- ----------------本文作者吴疆-------------- ------点击此处链接至博客园原文------ 1 ...

  5. python面向对象其他相关-异常处理-反射

    1.isinstance(obj, cls) 检查是否obj是否是类 cls 的对象   2.issubclass(sub, super) 检查sub类是否是 super 类的派生类 n1 = 10 ...

  6. python 面向对象(五)约束 异常处理 MD5 日志处理

    ###############################总结###################### 1.异常处理 raise:抛出异常 try: 可能出现错误代码 execpt 异常类 a ...

  7. day 018 面向对象--约束和异常处理

    ---恢复内容开始--- 主要内容; 类的约束 异常处理 自定义异常 MD5加密 日志 一  类的约束 (约束是对类的约束,) 看个例子: 这是领导分配给每个人的项目,要求每人写个功能 结果如下: 例 ...

  8. 第八章:Python基础の面向对象(二)

    本課主題 面向对象的多态 面向对象的成员 成员修饰符 特殊成员 面向对象其他应用 异常处理 设计模式与单例模式 面向对象的多态 指定参数类型只是多态的一种表现 另外一种是允许自己类型和自己的子类型(典 ...

  9. C错误异常处理,异常处理

    预处理器标识#error的目的是什么啊? 指令 用途 # 空指令,无任何效果 #include 包含一个源代码文件 #define 定义宏 #undef 取消已定义的宏 #if 如果给定条件为真,则编 ...

随机推荐

  1. zzulioj - 2628: 小新的字母广场

    题目链接:http://acm.zzuli.edu.cn/problem.php?id=2628 题目描述        放假了,小新决定出去散散心,于是他来到了著名的字母广场.这个广场是由n*m块砖 ...

  2. learning at command AT+CPIN

    [Purpose] Learning how to check sim ready? [Eevironment] Shell terminal, base on gcom command and gc ...

  3. windbg自行下载的sos.dll存放路径“..\SOS_x86_x86_4.7.3132.00.dll\5B5543296ee000\”里的“5B5543296ee000”是什么?

    问题的引出 我在调试某个崩溃问题时,要跟踪clr的栈,于是,我先执行了指令.loadby sos clrjit,没有报错,然后我又执行!clrstack,结果却有如下输出:0:000:x86> ...

  4. Thread线程框架学习

    原文:https://www.cnblogs.com/wangkeqin/p/9351299.html Thread线程框架 线程定义:线程可以理解为一个特立独行的函数.其存在的意义,就是并行,避免了 ...

  5. Collecting metrics with the PostgreSQL and TimescaleDB output plugin for Telegraf

    转自:https://docs.timescale.com/v1.3/tutorials/telegraf-output-plugin 文章演示了如何使用pg output 插件 以及Telegraf ...

  6. Log4net 控制台打印日志(二)

    1.创建控制台程序 2.用NuGet添加log4net引用 3.添加应用程序配置文件:App.config 4.添加配置信息: <?xml version="1.0" enc ...

  7. 2019-8-26 LinkedHashMap 转 List [java.util.LinkedHashMap cannot be cast to com.zq.dataservice.bean.Index]

    java.util.LinkedHashMap cannot be cast to com.zq.dataservice.bean.Index 上述错误是在做一个趋势投资demo时遇到的. 说的是链式 ...

  8. Kubernetes Pod概述

    Pod简介 Pod是Kubernetes创建或部署的最小/最简单的基本单位,一个Pod代表集群上正在运行的一个进程. 一个Pod封装一个应用容器,Pod代表部署的一个单位. Pods提供两种共享资源: ...

  9. Devops(四):Docker 镜像管理

    参考 <Docker中上传镜像到docker hub中> <Docker 镜像管理> <通过容器提交镜像(docker commit)以及推送镜像(docker push ...

  10. IDEA将指定package(指定文件)打成jar包

    写在前面 真的是好记性不如烂笔头 需求 将项目中包名为org的package打成jar包 步骤 1.选择Artifacts>绿色+号>JAR>Empty name自定义, 我这里命名 ...