错误与异常
错误一般指语法上面的错误
异常一般指在程序运行过程中出现的报错
错误与异常如果不加以处理,常常会导致程序崩溃
使用try-except
代码块可以捕捉到错误与异常,同时针对性的做出处理
例:
x = 1
y = 0
print(x/y)
当除数是0的时候,程序是无法得到结果的,此时会抛出异常:
Traceback (most recent call last):
File "C:\Users\Administrator\Desktop\code\code\read_file.py", line 4, in <module>
print(x/y)
ZeroDivisionError: division by zero
ZeroDivisionError异常表示因此除以了0而导致的异常
例:
while Ture
print(hello)
异常输出:
File "C:/Users/Administrator/Desktop/code/code/read_file.py", line 1
while Ture
^
SyntaxError: invalid syntax
SyntaxError指出了某句代码出现了语法错误,并用一个箭头指出了语句,这里是因为缺少冒号面导致的异常
如果不想让程序抛出异常,而是将异常信息告诉我们,然后做出相应的处理,则可以使用try-except
语句
例:
x = 1
y = 0
try:
print(x/y)
except ZeroDivisionError:
print("0无法做被数")
输出:
0无法做除数
try
语句块包装可能可能出问题的代码,如果程序发生了异常,将跳转到except
代码块中;在这里except
后面指出了异常类型,也就是说,如果抛出的异常是ZeroDivisionError
类型的,则执行print("0无法做除数")
语句
通过输出提示,不仅提醒了用户输入的信息有误,还防止了程序崩溃
try-except
语句还可配置else语句,如下:
x = 1
y = 1
number = 0
try:
number = x/y
except ZeroDivisionError:
print("0无法做被除数")
else:
print(str(number))
输出:
1.0
else
语句是在没有抛出异常的情况才执行的
再例如,打开一个不存在的文件时:
finename = 'hello.txt'
with open(finename) as f:
print(f.read())
输出:
Traceback (most recent call last):
File "C:/Users/Administrator/Desktop/code/code/read_file.py", line 3, in <module>
with open(finename) as f:
FileNotFoundError: [Errno 2] No such file or directory: 'hello.txt'
FileNotFoundError类型表示无法找到文件
如果我们提前对这种情况做了处理,则可以避免程序崩溃
finename = 'hello.txt'
try:
with open(finename) as f:
contents = f.read()
except FileNotFoundError:
print("对不起,找不到你要的文件")
else:
print(contents)
捕捉多个异常
except (RuntimeError, TypeError, FileNotFoundError):
pass
在except
语句中,多个异常类型用逗号隔开,并包装进无组中,如果抛出的异常符合其中一个类型,则会执行except
代码块
pass
表示什么也不做,只是个占位符
不指出异常类型
如果不知道程序到底会抛出什么类型的异常,则可以不指出异常类型,告诉Python,只要出现异常,就执行except
代码块
finename = 'hello.txt'
try:
with open(finename) as f:
contents = f.read()
except:
print("对不起,找不到你要的文件")
自定义异常
# 自定义异常类
class MyError(Exception):
def __init__(self, value):
self.value = value
def __str__(self):
return repr(self.value)
try:
# 通过raise关键字将异常类抛出
raise MyError("自定义异常类型")
except MyError as e:
print('捕捉异常', e.value)
输出:
捕捉异常 自定义异常类型
因为raise
可以将一个异常类抛出,因此,也可以直接使用Python中原有的异常类
raise NameError('名称不匹配')
输出:
Traceback (most recent call last):
File "C:/Users/Administrator/Desktop/code/code/read_file.py", line 1, in <module>
raise NameError('名称不匹配')
NameError: 名称不匹配
常用异常类型
异常名称 | 描述 |
---|---|
BaseException | 所有异常的基类 |
SystemExit | 解释器请求退出 |
KeyboardInterrupt | 用户中断执行(通常是输入^C) |
Exception | 常规错误的基类 |
StopIteration | 迭代器没有更多的值 |
GeneratorExit | 生成器(generator)发生异常来通知退出 |
StandardError | 所有的内建标准异常的基类 |
ArithmeticError | 所有数值计算错误的基类 |
FloatingPointError | 浮点计算错误 |
OverflowError | 数值运算超出最大限制 |
ZeroDivisionError | 除(或取模)零 (所有数据类型) |
AssertionError | 断言语句失败 |
AttributeError | 对象没有这个属性 |
EOFError | 没有内建输入,到达EOF 标记 |
EnvironmentError | 操作系统错误的基类 |
IOError | 输入/输出操作失败 |
OSError | 操作系统错误 |
WindowsError | 系统调用失败 |
ImportError | 导入模块/对象失败 |
LookupError | 无效数据查询的基类 |
IndexError | 序列中没有此索引(index) |
KeyError | 映射中没有这个键 |
MemoryError | 内存溢出错误(对于Python 解释器不是致命的) |
NameError | 未声明/初始化对象 (没有属性) |
UnboundLocalError | 访问未初始化的本地变量 |
ReferenceError | 弱引用(Weak reference)试图访问已经垃圾回收了的对象 |
RuntimeError | 一般的运行时错误 |
NotImplementedError | 尚未实现的方法 |
SyntaxError | Python 语法错误 |
IndentationError | 缩进错误 |
TabError | Tab 和空格混用 |
SystemError | 一般的解释器系统错误 |
TypeError | 对类型无效的操作 |
ValueError | 传入无效的参数 |
UnicodeError | Unicode 相关的错误 |
UnicodeDecodeError | Unicode 解码时的错误 |
UnicodeEncodeError | Unicode 编码时错误 |
UnicodeTranslateError | Unicode 转换时错误 |
Warning | 警告的基类 |
DeprecationWarning | 关于被弃用的特征的警告 |
FutureWarning | 关于构造将来语义会有改变的警告 |
OverflowWarning | 旧的关于自动提升为长整型(long)的警告 |
PendingDeprecationWarning | 关于特性将会被废弃的警告 |
RuntimeWarning | 可疑的运行时行为(runtime behavior)的警告 |
SyntaxWarning | 可疑的语法的警告 |
UserWarning | 用户代码生成的警告 |
try-finally语句
finally
表示不管有没有捕捉到异常,最终都要执行finally
代码块
如下:
try:
number = 10/0
except:
print('0无法做除数')
finally:
print('执行完毕')
输出:
0无法做除数
执行完毕