python 中的异常处理

本文介绍了如何在Python中使用try-except块捕获并处理IOError,以及如何自定义异常、使用raise语句和sys.exc_info()获取异常信息。同时讲解了如何通过logging模块记录异常到日志文件中。
摘要由CSDN通过智能技术生成
捕获异常

–捕获错误代码后 后面的代码依然执行

    try:
             fh = open("testfile", "w")
             fh.write("这是一个测试文件,用于测试异常!!")
    except IOError:
             print "Error: 没有找到文件或读取文件失败"
    else:
             print "内容写入文件成功"
     fh.close()

    try:
             #正常的操作
             #......................
    except:
             #发生异常,执行这块代码
             #......................
    else:
             #如果没有异常执行这块代码
              #
raise
可以使用raise语句自己触发异常

    def functionName( level ):
             if level < 1:
             raise Exception("Invalid level!", level)
     # 触发异常后,后面的代码就不会再执行
     #
sys.exc_info() 打印异常信息

except:
exc = sys.exc_info() #元组
print exc

logging.error(exc[1])

import logging
except:
exc = sys.exc_info() #元组
logging.error(exc[1])

日志文件记录
import logging  
logger = logging.getLogger()
#logfile = 'test.log'
hdlr = logging.FileHandler('/tmp/sendlog.txt')
formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
hdlr.setFormatter(formatter)
logger.addHandler(hdlr)
logger.setLevel(logging.NOTSET)

使用
logger.debug(“测试”)
logger.error(“测试”)



捕获错误代码后 后面的代码依然执行
try:
fh = open("testfile", "w")
fh.write("这是一个测试文件,用于测试异常!!")
except IOError:
print "Error: 没有找到文件或读取文件失败"
else:  
print "内容写入文件成功"         #---如果没有异常执行这块代码
fh.close()

手动抛出异常:
可以使用raise语句自己触发异常
def functionName( level ):
if level < 1:
raise Exception("Invalid level!", level)
        # 触发异常后,后面的代码就不会再执行

打印异常信息
except:
exc = sys.exc_info()  #元组
print exc

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值