本文主要是介绍Python接口自动化测试框架(基础篇)-- 讨厌的异常处理,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
文章目录
- 前言
- 错误和异常
- 异常处理
- 抛出异常
- 自定义异常
- 环境清理
- 扩展
前言
最后一篇基础文章了,在前面的学习及练习中,同学们是不是遇到一些问题呢?比如:变量使用之前未被定义;操作文件提示文件不存在;运算符操作时的错误?是的,遇到错误是在所难免的,问题是怎么处理这些错误,并且还能选择正常处理或中断程序。
错误和异常
语法错误和异常的区分,SyntaxError明显是表示语法错误,那么其他错误呢都是异常以其他错误的形式输出
- 语法错误是编译时就会报错的,如果是IDE工具会明显提示
>>> while True print("sss")File "<stdin>", line 1while True print("sss")^
SyntaxError: invalid syntax
- 异常呢就是运行过程中报错,程序大多数是在执行中无法处理的而直接报错
>>> prin("sss")
Traceback (most recent call last):File "<stdin>", line 1, in <module>
NameError: name 'prin' is not defined
- 区别且看:语法错误会在错误前后有个^符号,而一般异常呢;会告诉你是什么错误。
- 再看一个运算错误:
>>> "2" + 3
Traceback (most recent call last):File "<stdin>", line 1, in <module>
TypeError: can only concatenate str (not "int") to str# 类型错误,拼接字符串不能是int类型
- 如果+加法运算,咱把位置改变一下呢?
>>> 2 + "2"
Traceback (most recent call last):File "<stdin>", line 1, in <module>
TypeError: unsupported operand type(s) for +: 'int' and 'str'
- 注意:运算的时候,是由运算符左边的值或变量决定运算类型。
异常处理
它有一个公式:try…except…else…finally;表示try用来捕捉执行可能有异常的代码块,有异常则在except处理,没有异常则在else进行下一步处理,不管你有没有异常finally都会执行;try可以跟后面三个处理流程任意搭配组合使用,唯独不能try…else使用
- 异常处理正常流程如下:
try:a = "2" + 1
except:print("错误了吧")
else:print("没错误才输出")
finally:print("不管你什么情况,我都会执行")
- try可以跟踪多个except,有且只有一个except忽略异常的名称
try:a = 1 + "2"
except OSError as err:print("错误:{}".format(err))
except:print("通配的错误")
- try还可以跟一个包含多个错误的except组合
try:a += 1
except (RuntimeError, TypeError, NameError) as err:print(err)
- 不管except是几个,else只能在它后面,不能跟在try后面
- finally都只放在最后面,不管前面有多个或一个except或者else
抛出异常
处理不了的,或不想不处理,就直接抛异常;它可以在异常捕获中使用,也可以单独使用:raise Exception(“抛出异常信息”)
- raise关键字
# 它可以不带参数的try:a = 1 + "2"
except:raise
- raise 唯一的参数可以指定异常的类Exception,而不是Error
# 它可以带参数的x=34
if x > 5:raise Exception('x 不能大于 5。x 的值为: {}'.format(x))
- 扩展:traceback模块
它可以用来跟踪异常返回的信息,它提供了不同的方法对异常的输出有不同的处理,可以直接写文件,也可以对错误信息整理
自定义异常
这个可以在有开源项目的时候使用,在咱们自定义的框架中可以使用,一般都是直接或间接集成基类,如果是异常就继承Exception、如果是错误就继承Error。
环境清理
这个有用的方法跟finally有关,假使在某个代码块中执行失败,有资源打开,但是却没有回收(关闭),这时可以利用异常捕获来处理
- 还记得上篇的文件处理吗?
file = open("file.txt","r")content = file.read(30)print(content)file.close()# 假设在文件对象close之前报错,那么这个文件对象是没释放的
- 使用try…finally捕获
try:file = open("file.txt","r")content = file.read(30)print(content)
else:print("其他处理")
finally:file.close()# 这样不管文件对象做了啥,最后都会被finally执行close关闭资源
- 改进一下,之前学过的with上下文管理器,即在with打开文件,操作之后也有同样的效果
with open("file.txt","r") as pf:content = file.read(30)print(content)
扩展
python的标准异常;这个有很多,这里不一一举例了,可以上网百度看更多python异常类
- BaseException所有异常的基类
- Exception常规错误的基类
这篇关于Python接口自动化测试框架(基础篇)-- 讨厌的异常处理的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!