您现在的位置是:首页 > 文章详情

Python全栈工程师(异常(基础))

日期:2018-07-18点击:303

 

 

ParisGabriel
 
 
 
         每天坚持手写  一天一篇  决定坚持几年 为了梦想为了信仰
 
 

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. 修改原学生信息管理程序,加入异常处理语句,让程序在任何情况下都能够按逻辑正常执行.
例如:
输入成绩和年龄时,如果用户输入非法字符串也不会导致程序崩溃

 

原文链接:https://yq.aliyun.com/articles/620660
关注公众号

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。

持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。

文章评论

共有0条评论来说两句吧...

文章二维码

扫描即可查看该文章

点击排行

推荐阅读

最新文章