程序员

Python Learning-异常处理

2018-08-31  本文已影响4人  东南有大树

错误与异常

错误一般指语法上面的错误

异常一般指在程序运行过程中出现的报错

错误与异常如果不加以处理,常常会导致程序崩溃

使用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无法做除数
执行完毕

目录
上一章 Python Learning-文件处理

目录
上一章 Python Learning-异常处理
下一章 Python Learning-测试你的代码

上一篇下一篇

猜你喜欢

热点阅读