python 异常处理

import logging
#logging模块是用来记录错误信息,若增加了config,则可以记录在日志里方例查找
def foo(s):
    return 10/int(s)
def bar(s):
    return foo(s)*2
def main():
    try:
        bar('0')
    except Exception as e:
        logging.exception(e)

main()
print('END')

#raise抛出异常,捕获异常后可以将异常往外抛,此函数处理不了异常,可以向外层抛,例外面调用者处理此异常。就像员工处理不了事情向上抛给老板
def foo(s):
    n=int(s)
    if n==0:
        raise ValueError('invalid value: %s' %s)
    return 10/n
def bar():
    try:
        foo('0')
    except ValueError as e:
        raise
bar()

#错误调试
#(1)可以直接打印出变量值,或者断言或者是logging,或者是pdb,这个相当于pycharm中的debug
#以logging为例
import logging
logging.basicConfig(level=logging.INFO)

s='0'
n=int(s)
logging.info('n=%d' % n)
print(10/n)
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值