python使用笔记17--异常处理
什么是异常?
异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行。
一般情况下,在Python无法正常处理程序时就会发生一个异常。
异常是Python对象,表示一个错误。
当Python脚本发生异常时我们需要捕获处理它,否则程序会终止执行。
常见的异常
异常名称 | 描述 |
---|---|
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 | 用户代码生成的警告 |
异常处理
1 l = [1,2,3] 2 d = {} 3 try: 4 #print(l[2]) 5 print(d['name']) 6 except IndexError as e:#下标越界 7 print('下标不存在') 8 print(e) 9 except KeyError as e: 10 print('key不存在') 11 print(e) 12 else: 13 print('不出异常走到这里') 14 finally: 15 print('怎么样都会走到这里')
1 try: 2 #print(l[2]) 3 print(d['name']) 4 except Exception as e:#所有异常都可以捕获 5 print('下标不存在',e)
异常处理--小练习
1 import pymysql 2 mysql_info = {'host':'127.0.0.1', 3 'port':3306, 4 'user':'root', 5 'password':'123456', 6 'autocommit':True, 7 'db':'db001', 8 'charset':'utf8'} 9 10 def op_db(sql,one_tag=True): 11 try: 12 connect = pymysql.connect(**mysql_info) 13 except Exception as e: 14 print('数据库连接失败',e) 15 return '001' 16 else: 17 cur = connect.cursor() 18 try: 19 cur.execute(sql) 20 except Exception as e: 21 print('执行sql出错',e) 22 return '002' 23 else: 24 if one_tag: 25 result = cur.fetchone() 26 else: 27 result = cur.fetchall() 28 return result 29 finally: 30 cur.close() 31 connect.close()