1.try ....except ....else
如果except后面没有加东西:就是捕获所有yichang
except <异常名>:捕获指定异常
except <异常名> as <数据>: 捕获指定异常并将其赋给了<数据>;其中可以异常有多个,用元组表达
2.raise 引发异常
2.1 执行了raise后面的就不执行了
def printCount(count): if count == 100: raise ValueError print(count)# 例子中,当count==100时,会抛出ValueError
2.2 raise后面跟的语句,是有限制的,必须为Error或Exception类的子类
# python3中,dir(exceptions)不好用 import builtins dir(builtins)
2.3 raise后面可以是一个class、也可以是一个对象
def printCount(count): if count == 100: raise ValueError #这是class print(count) def printCount(count): if count == 100: raise ValueError("I am error") #这是ValueError的实例对象 print(count)
3 自定义一个异常类
自定义一个MyException类,继承Exception
class MyException(Exception): def __init__(self,message): Exception.__init__(self) self.message=message
如果输入的数字小于10,就引发一个MyException异常:
a=input("please input a num:") if a<10: try: raise MyException("my excepition is raised ") except MyException as e: print (e.message)
运行结果:
please input a num:1
my excepition is raised
4.traceback 跟踪异常
try: 1/0 except Exception,e: print e
输出结果是integer division or modulo by zero,只知道是报了这个错,但是却不知道在哪个文件哪个函数哪一行报的错。
下面使用traceback模块
import traceback try: 1/0 except Exception,e: traceback.print_exc()
输出结果是
Traceback (most recent call last):
File "test_traceback.py", line 3, in <module>
1/0
这样非常直观有利于调试。
traceback.print_exc()跟traceback.format_exc()有什么区别呢?
format_exc()返回字符串,print_exc()则直接给打印出来。
即traceback.print_exc()与print traceback.format_exc()效果是一样的。
print_exc()还可以接受file参数直接写入到一个文件。比如:
traceback.print_exc(file=open('tb.txt','w+'))
写入到tb.txt文件去
异常名称 | 描述 |
---|---|
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 | 用户代码生成的警告 |
来源:https://www.cnblogs.com/dinglei0001/p/12521182.html