放过错误最终会留下隐式 Bug,并且这些 Bug 更难被发现, Python 提供了健壮的错误处理。根据 Python 文档:“即使一个语句或表达式在语法上是正确的,在试图执行它时也可能会导致错误。”特别是对于大型项目,我们不希望在耗时的计算后,代码崩溃。这就是异常管理的魅力所在。
a = (1, 2, 3, "hey")
try:
for i in a:
b = 1 / (i - 1)
print(b)
except ZeroDivisionError as e: # 除数为零的异常,一个异常可以带上参数,可作为输出的异常信息参数。
print(e)
except Exception: # 其他异常,例如传入a是一个字符串
print("Unknown Error")
else: # 如果没有触发错误就执行
print("Perfect code")
finally: # 不管是否触发错误都执行
print("Finished")
division by zero
Finished
a = ("hey", 1, 2, 3)
try:
for i in a:
b = 1 / (i - 1)
print(b)
except ZeroDivisionError as e: #除数为零的异常,一个异常可以带上参数,可作为输出的异常信息参数e。
print(e)
except Exception: # 其他异常,例如传入a是一个字符串
print("Unknown Error")
else: # 如果没有触发错误就执行
print("Perfect code")
finally: # 不管是否触发错误都执行。
print("Finished")
Unknown Error
Finished
当程序出现错误,python会自动引发异常,也可以通过raise显示地引发异常。一旦执行了raise语句,raise后面的语句将不能执行。
try:
s = None
if s is None:
print "s 是空对象"
raise NameError # 如果引发NameError异常,后面的代码将不能执行
print(len(s)) #这句不会执行,但是后面的except还是会执行
except TypeError:
print("空对象没有长度")