18-异常处理及测试
1 异常处理
1.1 try…except
有时候我们写程序的时候,会出现一些错误或异常,导致程序终止。例如,做除法时,除数为0,会引起一个ZeroDivisionError。
例子:
a = 5
b = 0
c = a / b
print('done')
输出:
Traceback (most recent call last):
File "A:/pycharm/python_workspace/demo/main.py", line 3, in <module>
c = a / b
ZeroDivisionError: division by zero
我们发现程序因为ZeroDivisionError而中断了,语句print (‘done’) 没有运行。为了处理异常,我们使用try…except,更改代码:
a = 5
b = 0
try:
c = a / b
print(c)
except ZeroDivisionError as e:
print(e)
print('done')
>>>division by zero
>>>done
这样程序就不会因为异常而中断,从而print (‘done’)语句正常执行。
我们把可能发生错误的语句放在try模块里,用except来处理异常。except可以处理一个专门的异常,也可以处理一组圆括号中的异常,如果except后没有指定异常,则默认处理所有的异常。每一个try,都必须至少有一个except
处理一组异常可以这样写(其中e代表异常的实例):
a = 5
b = 0
try:
c = a / b
print(c)
except (IOError ,ZeroDivisionError) as e:
print(e)
print('done')
>>>division by zero
>>>done
try …except…else 语句,当没有异常发生时,else中的语句将会被执行。
例子:
a = 5
b = 0
try:
c = b / a
print(c)
except (IOError ,ZeroDivisionError) as e:
print(e)
else:
print('no error')
print('done')
输出:
0.0
no error
done
1.2 raise 引发一个异常
例子:如果输入的数据不是整数,则引发一个ValueError
input_value = int(input('请输入一个整数:'))
if type(input_value) != type(1):
raise ValueError
else:
print(input_value)
输出:
请输入一个整数:1.1
Traceback (most recent call last):
File "A:/pycharm/python_workspace/demo/main.py", line 1, in <module>
input_value = int(input('请输入一个整数:'))
ValueError: invalid literal for int() with base 10: '1.1'
1.3 try …finally
无论异常是否发生,在程序结束前,finally中的语句都会被执行:
a = 5
b = 0
try:
c = a / b
print(c)
finally:
print('always excute')
输出:
Traceback (most recent call last):
always excute
File "A:/pycharm/python_workspace/demo/main.py", line 4, in <module>
c = a / b
ZeroDivisionError: division by zero
虽然有异常发生,但在程序终止前,finally中的语句也能正常执行。finally语句也可以和except语句一起使用:
a = 5
b = 0
try:
c = a / b
print(c)
except:
print('error')
finally:
print('always excute')
>>>error
>>>always excute
1.4 python所有的标准异常类:
2 测试
创建一个main.py文件,写入以下内容:
def get_formatted_name(first, last):
full_name = '{} {}'.format(first, last)
return full_name.title()
print(get_formatted_name('tom', 'lee'))
>>>Tom Lee
再创建一个test_name_function.py文件:
import unittest
from main import get_formatted_name
class NameTestCase(unittest.TestCase):
def test_title_name(self):
formatted_name =