1 两种编程风格LBYL和EAFP
LBYL: look before you leap , 先判断再操作,如果条件不满足就不操作或者返回错误。
EAFP: easier to ask for forgiveness , 请求原谅比请求许可简单。 意思是先做应该做的事,如果出错了,抛出异常并处理该事实,相当于请求原谅。 这种做法比请求许可要更简单。
LBYL的写法:
def add_one(value):
"""对输入的数字加1,并返回
:param value: 整数或者可以转换为整数的数字
:return: 整型结果
"""
if isinstance(value,int):
return value+1
elif isinstance(value,str) and value.isdigit():
return int(value) + 1
else:
print(f'{value} is unable to int')
EAFP的写法:
def add_one(value):
"""对输入的数字加1,并返回
:param value: 整数或者可以转换为整数的数字
:return: 整型结果
"""
try:
return int(value) + 1
except (TypeError,ValueError) as e:
print(f'{value} is unable to int')
与LBYL相比,EAFP更加的简单直接,python更加的偏爱于EAFP的代码风格。 减少了if/else的判断,与其他语言相比python的异常非常的轻量级,不会影响性能。
2 try语句基本知识
1、把精确的except语句放在前面
exception异常类有很多继承关系,BaseException -- Exception -- LookupError -- KeyError
包含多个except的时候,异常匹配会从上往下顺序进行,这个时候要把子类异常排在前面,大的异常排在后面。
2、 使用else分支
try:
dosomething()
except (TypeError,ValueError) as e:
print(f'{value} is unable to int')
else:
print(f'then.....')
执行try,如果没有异常就执行else中的语句。
3、使用空raise语句
在处理异常的时候,仅仅只是记录异常,然后将异常重新抛出,交由上层处理,这时使用不带任何参数的raise语句就可以满足要求,原封不动的抛出当前异常。
4、可以通过继承异常类,自定义异常,在某些业务处理过程中,如果处理失败,抛出对应处理业务的异常类。
3 with 上下文管理器
with定义关键字可以管理一段上下文,并且控制进入和退出这段上下文时的行为。
with open('log.txt') as fp:
content = fp.read()
可以通过自定义实现上下文协议的对象,也能满足该要求,需要实现__enter()__和__exit()__魔法方法。
上下文管理器这种操作简化了,finally的处理。