如果except后面没有加东西:就是捕获所有yichang
except <异常名>:捕获指定异常
except <异常名> as <数据>: 捕获指定异常并将其赋给了<数据>;其中可以异常有多个,用元组表达
def printCount(count): if count == 100: raise ValueError print(count)
# 例子中,当count==100时,会抛出ValueError
# python3中,dir(exceptions)不好用 import builtins dir(builtins)
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)
自定义一个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
import traceback try: 1/0 except Exception,e: traceback.print_exc()
这样非常直观有利于调试。
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