错误
- 语法错误(syntax error)
- 逻辑错误(logic error)
- 执行期间错误(runtime error)
demo:
for i in range(10):
print(i)
out—>
for i in range(10):
SyntaxError: invalid syntax
python的语法分析器完成,检测到错误文件和行号。以上箭头标记错误位置,最后显示错误类型。
按顺序检测到一个错误,解释器就无法继续执行下去,抛出异常,终止程序。
异常
系统根据不同的错误,抛出不同异常
常见异常:
异常 | 描述 |
---|---|
NameError | 尝试访问一个没有申明的变量 |
ZeroDivisionError | 除数为 0 |
SyntaxError | 语法错误 |
IndexError | 索引超出序列范围 |
KeyError | 请求一个不存在的字典关键字 |
FileNotFoundError | 文件未发现错误(比如你要读的文件不存在) |
AttributeError | 尝试访问未知的对象属性 |
ModuleNotFoundError | 模块未发现 |
IndentationError | 缩进 |
异常处理
程序一旦发生错误,程序就无法继续运行。
为了使程序健壮,可做相关异常处理。
try…except…
try:
try_statements
except [exceptionType [as identifier]]:
except_statements
[else:
else_statements]
[finally:
finally_statements]
- try子句
- try … except 必须放在可能发生异常的程序段周围,而try_statements则是可能发生异常的程序段。
- except子句
- 用来捕捉指定的异常,一旦捕捉到,就执行与之对应的except_statements,即用来处理异常的程序语句。
- 如果要针对不同的异常做不同的处理,可以使用多个except子句,其中,exceptionType是欲捕捉的异常类型,省略不写,表示为预设类型:BaseException,所有异常都继承自该类别。
- [as identifier]可以将捕捉到的异常指向一个变量,然后,通过该变量获得异常相关的信息。
- 不带任何异常类型使用except,将捕获所有发生的异常。不推荐这么使用,因为我们不能通过该程序识别出具体的异常信息。
- else子句
- 当try_statements没有异常发生时,会跳过except子句,执行else_statements。
- 该子句为可选语句,可以指定或者省略。
- finally子句
- 当要离开try … except 时(无论异常是否发生),就会执行finally_statements,可以使清除错误或者收尾的语句。可给可忽略。
try:
X = eval(input("请输入被除数x:\t"))
Y = eval(input("请输入除数y:\t"))
Z = X / Y
except ZeroDivisionError:
print("除数不可以为0")
except NameError:
print("请检查变量是否赋值")
else:
print("未捕捉到异常,X/Y=", Z)
finally:
print("离开try...except模块")
'''
1.
请输入被除数x: 20
请输入除数y: 0
除数不可以为0
离开try...except模块
2.
请输入被除数x: 15
请输入除数y: a
请检查变量是否赋值
离开try...except模块
'''
try:
X = eval(input("请输入被除数x:\t"))
Y = eval(input("请输入除数y:\t"))
Z = X / Y
except Exception as e:
print(e.args)
#except (ZeroDivisionError, NameError, TypeError) as e:
# print(e.args)
else:
print("未捕捉到异常,X/Y=", Z)
finally:
print("离开try...except模块")
'''
1.
请输入被除数x: 18
请输入除数y: 0
('division by zero',)
离开try...except模块
2.
请输入被除数x: 92
请输入除数y: 4
未捕捉到异常,X/Y= 23.0
离开try...except模块
'''
raise(触发异常)
除了系统抛出的异常,还可以用raise语句去触发异常
格式:
raise [Exception[,args [,traceback]]]
Exception:异常类型
args:我们自己提供的异常参数
traceback:可选,如果存在,跟踪异常对象
assert(断言)
assert condition
逻辑上相当于
if not condition:
raise AssertionError()
为断言添加一个异常参数
assert expression[,args]