Python笔记(22)-异常处理与调试

python所有的标准异常类

异常名称

描述

BaseException

所有异常的基类

SystemExit

解释器请求退出

KeyboardInterrupt

用户中断执行(通常是输入^C)

Exception

常规错误的基类

StopIteration

迭代器没有更多的值

GeneratorExit

生成器(generator)发生异常来通知退出

SystemExit

Python 解释器请求退出

StandardError

所有的内建标准异常的基类

ArithmeticError

所有数值计算错误的基类

FloatingPointError

浮点计算错误

OverflowError

数值运算超出最大限制

ZeroDivisionError

除(或取模)零 (所有数据类型)

AssertionError

断言语句失败

AttributeError

对象没有这个属性

EOFError

没有内建输入,到达EOF 标记

EnvironmentError

操作系统错误的基类

IOError

输入/输出操作失败

OSError

操作系统错误

WindowsError

系统调用失败

ImportError

导入模块/对象失败

KeyboardInterrupt

用户中断执行(通常是输入^C)

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

用户代码生成的警告

错误

[root@python code12]# vim error_operate.py

print "try..."

a=10/0              #0不能当除数,所以一定会报错

执行结果:

[root@python code12]# python error_operate.py 
try...      #可以看到try...是成功打印了
Traceback (most recent call last):
File "error_operate.py", line 2, in <module>
a=10/0
ZeroDivisionError: integer division or modulo by zero

#脚本中第二行内容报ZeroDivisionError错误,查询Python所有标准异常,发现是除(或取模)零 (所有数据类型)错误

错误处理

• 在程序运行的过程中,如果发生了错误,可以事先约定返回一个错误代码;

• Python语言通常都内置了一套 try...except...finally... 的错误处理机制;

• 错误有很多种类(见文章开头Python所有标准异常),如果发生了不同类型的错误,应该由不同的 except语句块处理。因此可以有多个 except 来捕获不同类型的错误;

• Python 的错误其实也是 class,所有的错误类型都继承自BaseException;
• 在使用except 捕获该类型(BaseException)的错误,还把其它子类也“一网打尽”,如下面的脚本将ZeroDivisionError换为BaseException结果是一样的;
• 常见的错误类型和继承关系参考这里:https://docs.python.org/2/library/exceptions.html#exceptionhierarchy

try...except...finally... 的错误处理机制:

- 用 try 来运行可能会出错的代码;
- 如果执行正确,则except 语句块不会执行;
- 如果执行错误,直接跳转至错误处理代码,即except语句块;
- 如果有 finally 语句块,不管try语句块内容是否正确,都会执行 finally语句块

修改刚才的脚本,加入try...except...finally... 的错误处理机制:

[root@python code12]# vim error_operate.py

#coding:utf-8try:

    print "try..."

    a=10/0except (ZeroDivisionError,),e:

    pass    #如果脚本出现ZeroDivisionError错误直接pass,不打印任何结果

#当然pass这里也可以改为任何想自定义的内容,如print "number error"等,只要脚本出现ZeroDivisionError错误就会打印出自定义的内容,而不是系统默认报错内容
finally:

    print "运行结束"

执行结果:

[root@python code12]# python error_operate.py 
try...
运行结束

#对比之前的脚本,这次对于10/0没有输出报错

抛出错误
• 错误是 class,捕获一个错误就是捕获到该 class 的一个实例;
• Python 的内置函数会抛出很多类型的错误,我们自己编写的函数也可以抛出错误
• 可以定义一个错误的 class,选择好继承关系,然后,用raise 语句抛出一个错误的实例
• 尽量使用 Python 内置的错误类型

 

调试- logging

• logging 不会抛出错误,而且可以输出到文件;
• logging.info() 就可以输出一段文本到日志文件中。
• logging.basicConfig(level=logging.INFO)指定记录信息的级别,有DEBUG , INFO , WARNING , ERROR等几个级别,其中ERROR级别最高,如果level=logging.INFO这里用level=logging.ERROR代替就不会输出比ERROR级别低的错误了

 

查看生成的/tmp/test.log中的内容:

[vaon@station ~]$ cat /tmp/test.log 
INFO:root:age=10
WARNING:root:age=10

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值