每天坚持手写 一天一篇 决定坚持几年 为了梦想为了信仰
Python人工智能从入门到精通
补充:包的相对导入 只对后两种导入方式有用 前两次改进的学生管理系统在20课中 已补充
异常(基础)except:
什么是错误:
是指由于逻辑或语法等导程序无法正常执行的问题
什么是异常:
是程序出错的标识符的一种状态
当异常发时 程序不会再向下执行,而转去调用此函数的地方
待处理此错误并恢复为正常状态
异常的作用:
用作信号, 通知上层调用者有错误产生需要处理
try 语句:
两种语法:
ry-except语句(接受异常通知)
try-finally语句
try-except 语法 :
try:
可能触发异常的语句
except 错误类型1[as 变量1]:
异常处理语句2
except 错误类型2[as 变量2]:
异常处理语句2
except (错误类型3, 错误类型4,...)[as 变量3]:
异常处理语句3
......
except:
异常处理语句(其他)(匹配所有类型错误)
else:
未发生异常语句(可以没有此语句 没有发成异常时调用)
finlly:
最终语句
作用:
尝试捕获异常, 将程序由异常状态转为正常状态并正常执行
说明:
1. as 子句是用于绑定错误对象的变量,可以省略
2. except 子句可以有一个或多个,但至少要有一个
3. else 子句最多只能有一个,也可以省略不写
4. finally 子句最多只能有一个,也可以省略不写
5. else 子句将在try没有出现异常时执行
6. finally子句的语句在任何情况下都会被执行
示例:
# 此示例示意用try-except 语句捕获异常并做出相应的处理
def div_apple(n):
print("%d个苹果您想分给几个人?" % n)
s = input("请输入人数: ")
cnt = int(s) # <- 此处可能触发ValueError类型错误
result = n / cnt # <- 此处可能触发ZeroDivisitionError错误
print("每个人分了%d个苹果" % result)
try:
print("开始分苹果")
div_apple(10) # 可能触发异常的调用
print("结束分苹果")
except ValueError:
print("发生成值错误,已处理并转为正常状态!")
except ZeroDivisionError:
print("发生了被零除的错误,程序已转为正常状态")
print("程序正常执行并完全任务,退出程序")
try-finally语法:
try:
可能触发异常的语句
finally:
最终语句
说明:
1.finally子句不可以省略
2.一定不存在except子句
作用:
通常try-finally语句来做触发异常时必须要处理的事情
无论异常是否发生, finally子句一定会被执行
注意:
try-finally 语句不会改变程序的(正常/异常)状态
示例:
# 以下以 煎蛋为例示意 try-finally语句的用法
# 必须要做的事情是,关闭天燃气
def fry_egg():
print("打开天燃气点燃...")
try:
count = int(input("请输入鸡蛋个数: "))
print("完成煎鸡蛋,共煎了%d个鸡蛋" % count)
finally:
print("关闭天燃气")
fry_egg()
raise 语句:(发起异常通知)
作用:
触发一个错误, 让程序进入异常状态
语法:
raise 异常类型
或
raise 异常对
实例:
def make_exception():
print("函数开始")
# 发出一个ValueError类型的错误通知给调用者
# raise ValueError
err = ValueError("这是自定义的错误数据")
raise err # 用 err触发一个异常通知
print("函数结束")
try:
make_exception()
print("make_exception调用结束!")
except ValueError as e:
print("接收到ValueError类型的异常通知")
print("错误对象是:", e)
assert 断言语句:
语法:
assert 真值表达式, 错误数据(通常是字符串)
作用:
当真值表达式为False时, 用错误数据创建一个AssertionError
类型的错误, 并进入异常状态
等同于:
if 真值表达式 == false
raise AssertrtionError(错误数据)
实例:
def get_score():
s = int(input("请输入学生成绩: "))
assert 0 <= s <= 100, '成绩超出范围'
# if not (0 <= s <= 100):
# raise AssertionError('成绩超出范围')
return s
try:
score = get_score()
except AssertionError as err:
print("错误数据是:", err)
print('获取成绩失败')
score = 0
print("学生的成绩为:", score)
小结:
异常处理语句(4条):
try-except 语句:
用于接受异常通知, 捕获异常
try-finally 语句:
执行必须执行的语句
raise 语句:
发送异常通知, 并进入异常状态
assert 语句:
根据条件选着性的发送 AssertionError类型的异常通知
为什么要处理异常机制:
在程序调用层数比较深的时候, 向主调用函数传递错误信息 需要层层return返回
比较麻烦, 用异常处理机制可以较简单的传递错误信息
Python全部的错误类型
| 错误类型 |
说明 |
| 以下内容必讲 |
|
| ZeroDivisionError |
除(或取模)零 (所有数据类型) |
| ValueError |
传入无效的参数 |
| AssertionError |
断言语句失败 |
| StopIteration |
迭代器没有更多的值 |
| IndexError |
序列中没有此索引(index) |
| IndentationError |
缩进错误 |
| OSError |
输入/输出操作失败 |
| ImportError |
导入模块/对象失败 |
| NameError |
未声明/初始化对象 (没有属性) |
| AttributeError |
对象没有这个属性 |
| |
|
| GeneratorExit |
生成器(generator)发生异常来通知退出 |
| TypeError |
对类型无效的操作 |
| KeyboardInterrupt |
用户中断执行(通常是输入^C) |
| OverflowError |
数值运算超出最大限制 |
| FloatingPointError |
浮点计算错误 |
| BaseException |
所有异常的基类 |
| SystemExit |
解释器请求退出 |
| Exception |
常规错误的基类 |
| StandardError |
所有的内建标准异常的基类 |
| ArithmeticError |
所有数值计算错误的基类 |
| EOFError |
没有内建输入,到达EOF 标记 |
| EnvironmentError |
操作系统错误的基类 |
| WindowsError |
系统调用失败 |
| LookupError |
无效数据查询的基类 |
| KeyError |
映射中没有这个键 |
| MemoryError |
内存溢出错误(对于Python 解释器不是致命的) |
| UnboundLocalError |
访问未初始化的本地变量 |
| ReferenceError |
弱引用(Weak reference)试图访问已经垃圾回收了的对象 |
| RuntimeError |
一般的运行时错误 |
| NotImplementedError |
尚未实现的方法 |
| SyntaxError Python |
语法错误 |
| TabError |
Tab 和空格混用 |
| SystemError |
一般的解释器系统错误 |
| UnicodeError |
Unicode 相关的错误 |
| UnicodeDecodeError |
Unicode 解码时的错误 |
| UnicodeEncodeError |
Unicode 编码时错误 |
| UnicodeTranslateError |
Unicode 转换时错误 |
| 以下为警告类型 |
|
| Warning |
警告的基类 |
| DeprecationWarning |
关于被弃用的特征的警告 |
| FutureWarning |
关于构造将来语义会有改变的警告 |
| OverflowWarning |
旧的关于自动提升为长整型(long)的警告 |
| PendingDeprecationWarning |
关于特性将会被废弃的警告 |
| RuntimeWarning |
可疑的运行时行为(runtime behavior)的警告 |
| SyntaxWarning |
可疑的语法的警告 |
| UserWarning |
用户代码生成的警告 |
| 详见:help(builtins) |
练习:
写一个函数 get_score() 来获取学生成绩,
要求用户输入 1~100的整数,输果输入出现异常,返此函数返回0,
否则返回用户输入的成绩
示例:
def get_score():
...
score = get_score()
print("学生的成绩是:", score)
练习:
1. 一个球从100米高空落下 ,每次落地后反弹高度是原高度的一半, 在落下
1)写程序算出皮球在第10次落地后反弹高度是多高?
2)打印出球共经过多少米的路程
答案:
def ball(n, m):
L = [100]
while True:
if n == 0:
print("最后弹起的高度是%s米" % s)
break
s = m * 0.5
m = s
L.append(s + m)
n -= 1
return L
print("10次共经历了%s米的路程" % sum(ball(10, 100)))
![]()
2. 分解质因数, 输入一个整数, 分解质因数 ,
如:
输入 90
则打印:
“90=2*3*3*5”
(质因数是指最小能被原数整除的素数 不包括1)
答案:
def m(n):
ret = []
while n > 1:
for i in range(n):
k = i + 2
if n % k == 0:
ret.append(k)
n = int(n / k)
break
return ret
print(m(90))
![]()
3. 修改原学生信息管理程序,加入异常处理语句,让程序在任何情况下都能够按逻辑正常执行.
例如:
输入成绩和年龄时,如果用户输入非法字符串也不会导致程序崩溃