一、异常处理
在程序运行的过程中,总会遇到各种各样的错误。程序一出错就停止运行了,下面的代码就不能运行了;这时候就需要捕捉异常,通过捕捉异常,再去做对应的处理。
e.g: info = { "id":1, "name":"小黑", "sex":"nan" } choice = input("请输入你要查看的属性:") print(info[choice]()) #非函数不能调用
像这种情况我们就需要捕捉异常;捕捉异常使用try....except....关键字,就是你在写代码的时候,先要考虑到这段代码可能会出现什么样的错误,然后做对应的处理,try里面是可能出错的代码,except里面是出错了要执行的代码;下面是我们改进后的代码:
try : print(info[choice]()) # print(type(info[choice])) except Exception as e: #除去,如果出异常再怎么处理 #except Exception ,e: python2 #Exception能扑捉到所有的异常 print('出错了,错误信息是:',e) #e代表异常信息
eg2: 链接数据库
def op_mysql(sql): try : #可能出错的代码 coon = pymysql.connect(host=MYSQL_HOST,user=MYSQL_USER,passwd=MYSQL_PASSWD,port=MYSQL_PORT,db=MYSQL_DB,charset='utf8') except Exception as e: #出错后执行的代码 raise e else: cur = coon.cursor(cursor=pymysql.cursors.DictCursor)#不出错执行 try: cur.execute(sql) except Exception as e: raise e else: if sql.startswith('select'): res =cur.fetchone() print(res) else: coon.commit() res =88 return res finally: #不管成功失败都要执行 cur.close() coon.close()
二、常见的一些异常信息:
如果自己能明确错误类型是那种错误就执行 except 具体错误 as e;如果不明确是那种错误就用Exception它会捕捉所有的错误
AttributeError: 试图访问一个对象没有的属性,比如foo.x,但是foo没有属性x
IOError:输入/输出异常,一般是无法打开文件
ImportError: 无法导入模块或包,一般是路径问题或名称错误
IndentationError:代码没有正确对齐,属于语法错误
IndexError:下标索引超出序列边界,比如x只有三个元素,却试图访问x[3]
KeyError:试图访问字典里不存在的键
KeyboardInterrupt:Ctrl+C被按下
NameError:使用一个还未被赋予对象的变量
SyntaxError: 语法错误
TypeError: 传入对象类型与要求的不符
UnboundLocalError:试图访问一个还未被设置的局部变量,一般是由于在代码块外部还有另一个同名变量
ValueError: 传入一个调用者不期望的值,即使值的类型是正确的
三、主动抛出异常
主动抛出异常,就是我们在代码里面让它自动抛出一个异常,然后捕捉到
def is_correct_sql(sql): #select update insert delete truncate drop create alter sql_start = ['select','update','insert','delete','truncate','drop','create','alter'] for start in sql_start: if sql.startswith(start): return True else: raise TypeError #'SQL错误!!! ' #主动抛出异常, is_correct_sql('dddd')