错误和异常

错误和异常

错误

  • 语法错误(syntax error)

  • 逻辑错误(logic error)

  • 执行期间错误(running error)

demo:

for i in range(10):
    print(i)

out—>

	for i in range(10)
                     ^
SyntaxError:invalid syntax

python的语法分析器,检测到错误所在文件和行号。以向上箭头标记错误位置。最后显示错误类型。

当程序检测到一个错误,解释器就无法继续执行下去,抛出异常,终止程序。

异常

系统根据不同的错误,抛出不同的异常。

常见异常:

>>> 1/0
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ZeroDivisionError: division by zero
>>> a=10
>>> a
10
>>> b
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: name 'b' is not defined
>>> for i in range(10)
  File "<stdin>", line 1
    for i in range(10)
                     ^
SyntaxError: invalid syntax
>>> li=[1,2,3]
>>> li[3]
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
IndexError: list index out of range
>>> import self_define_module
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
ModuleNotFoundError: No module named 'self_define_module'
异常描述
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,可以使清除错误或者收尾的语句。可给可忽略。

raise(触发异常)

除了系统抛出的异常,我们可以用raise语句自己触发异常。

格式:

raise [Exception [, args [,traceback]]]
  • Exception:异常类型
  • args:我们自己提供的异常参数。
  • traceback:可选,如果存在,跟踪异常对象。
>>> raise NameError("Sorry, Error occurs")
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
NameError: Sorry, Error occurs
>>>

assertd(断言)

assert condition

逻辑上相当于:

if not condition:
    raise AseeertionError()
>>> assert 1==1
>>> assert 1==0
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AssertionError
>>> li=[1,2]
>>> assert len(li)>=5,"列表元素个数小于5"
Traceback (most recent call last):
  File "<stdin>", line 1, in <module>
AssertionError: 列表元素个数小于5

为断言添加一个异常参数

assert expression[,args]

arguments

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值