码迷,mamicode.com
首页 > 编程语言 > 详细

python之异常处理

时间:2018-02-27 23:22:39      阅读:132      评论:0      收藏:0      [点我收藏+]

标签:pymysql   关闭   sql   修改   ima   ==   执行   info   img   

先来看一段代码:

def calc(a,b):
res = a/b
return res

def main():
money = input(‘输入多少钱:‘)
month = input(‘还几个月:‘)
res = calc(int(money), int(month))
return res

main()

运行的时候money输入10,month输入0,查看结果:

技术分享图片

运行的时候money输入aa,month输入hhh,查看结果:hhh

 技术分享图片

在运行过程中我们需要对异常进行处理,让代码能继续执行之后的部分,修改代码:

def main():
money = input(‘输入多少钱:‘)
month = input(‘还几个月:‘)
try:
res = calc(int(money),int(month))
except ZeroDivisionError as e: #try里面的代码出错,走except
print(‘还款的月数不能是0‘, e)
print(‘每个月应该还%s‘ % res)

运行的,money输入10,month输入0,查看结果:

技术分享图片

仍然出错的原因是因为try里面的代码出错,走except,res根本没有值,所以我们再次修改代码:

def main():
money = input(‘输入多少钱:‘)
month = input(‘还几个月:‘)
try:
res = calc(int(money),int(month))
except ZeroDivisionError as e: #try里面的代码出错,走except
print(‘还款的月数不能是0‘, e)
else:
print(‘每个月应该还%s‘ % res)

 当我们输入字母时依然报错,我们可以继续修改代码:

def main():
money = input(‘输入多少钱:‘)
month = input(‘还几个月:‘)
try:
res = calc(int(money),int(month))
except ZeroDivisionError as e: #try里面的代码出错,走except
print(‘还款的月数不能小于1‘,e)
except ValueError as e: #继续捕获其他异常
print(‘输入的必须是整数。%s‘%e)
else:
print(‘每个月应该还%s‘%res)

 代码可能还存在很多未知异常,而我们无法预知,为了使得代码执行中不会因为报错而终止运行,我们可以修改代码捕获全部异常:

def main():
money = input(‘输入多少钱:‘)
month = input(‘还几个月:‘)
try:
res = calc(int(money),int(month))
except ZeroDivisionError as e: #try里面的代码出错,走except
print(‘还款的月数不能小于1‘,e)
except ValueError as e: #继续捕获其他异常
print(‘输入的必须是整数。%s‘%e)
except Exception as e: #捕捉全部异常
print(‘捕捉全部的异常%s‘%e)
else:
print(‘每个月应该还%s‘%res)

 当我们使用try时同样也可以捕获完整的报错信息,需要引入一个新的模块traceback,修改代码:

import traceback
def main():
money = input(‘输入多少钱:‘)
month = input(‘还几个月:‘)
try:
res = calc(int(money),int(month))
except ZeroDivisionError as e: #try里面的代码出错,走except
traceback.print_exc() #只是输出报错的详细信息,不影响代码运行
print(‘还款的月数不能小于1‘,e)
except ValueError as e: #继续捕获其他异常
print(‘输入的必须是整数。%s‘%e)
except Exception as e: #捕捉全部异常
print(‘捕捉全部的异常%s‘%e)
else:
print(‘每个月应该还%s‘%res)

执行结果:

技术分享图片

==================================我是分割线==================================================

import pymysql
def main2():
try:
conn = pymysql.connect(host=‘122.932.122.11‘, user=‘root‘, password=‘123456‘, db=‘test‘)
except Exception as e:
print(‘数据库连接不了,%s‘ %e)
else:
cur = conn.cursor()
except Exception as e:
print(‘sql语句有错误!%s。sql是"%s‘ % (e, sql))
else:
res = cur.fetchall()
return res
#except和else不会同时走到,只能走其中的一样,所以需要把关闭游标和连接放在两个分支
finally: #不管有没有捕捉到异常,都会走到这里
cur.close()
conn.close()

 ==================================我是分割线==================================================

import requests
def req():
r = requests.get(‘http://api.nnzhp.cn/api/user/all_stu‘,headers={‘Referer‘:‘http://api.nnzhp.cn/‘})
if len(r.json()[‘stu_info‘])<0:
pass
else:
raise Exception(‘接口没数据‘) #主动抛出异常
req()

python之异常处理

标签:pymysql   关闭   sql   修改   ima   ==   执行   info   img   

原文地址:https://www.cnblogs.com/mpp0905/p/8480895.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!