二.python面对对象 ------5异常与日志

 
 
一 .异常

什么是异常?
异常即是一个事件,该事件会在程序执行过程中发生,影响了程序的正常执行。
一般情况下,在Python无法正常处理程序时就会发生一个异常。
异常是Python对象,表示一个错误。
当Python脚本发生异常时我们需要捕获处理它,否则程序会终止

异常处理
捕捉异常可以使用try/except语句。
try/except语句用来检测try语句块中的错误,从而让except语句捕获异常信息并处理。
如果你不想在异常发生时结束你的程序,只需在try里捕获它。

语法:
以下为简单的try....except...else的语法:
try:
<语句>        #运行别的代码
except <名字>:
<语句>        #如果在try部份引发了'name'异常
except <名字>,<数据>:
<语句>        #如果引发了'name'异常,获得附加的数据
else:
<语句>        #如果没有异常发生


try的工作原理是:
   当开始一个try语句后,python就在当前程序的上下文中作标记,
   这样当异常出现时就可以回到这里,try子句先执行,接下来会发生什么依赖于执行
   时是否出现异常。如果当try后的语句执行时发生异常,python就跳回到try并执行第
   一个匹配该异常的except子句,异常处理完毕,控制流就通过整个try语句
  (除非在处理异常时又引发新的异常)。如果在try后的语句里发生了异常,
   却没有匹配的except子句,异常将被递交到上层的try,或者到程序的最上层
  (这样将结束程序,并打印缺省的出错信息)。如果在try子句执行时没有发生异常,
   python将执行else语句后的语句(如果有else的话),然后控制流通过整个try语句


 实例
 下面是简单的例子,它打开一个文件,在该文件中的内容写入内容,且并未发生异常:
try:
    fh = open("testfile", "w")
    fh.write("这是一个测试文件,用于测试异常!!")
except IOError:
    print ("Error: 没有找到文件或读取文件失败")
else:
    print("内容写入文件成功")
    fh.close()

以上程序输出结果:
$ python test.py
内容写入文件成功
$ cat testfile       # 查看写入的内容
这是一个测试文件,用于测试异常!!



 实例
  下面是简单的例子,它打开一个文件,在该文件中的内容写入内容,
   但文件没有写入权限,发生了异常:
try:
    fh = open("testfile", "w")
    fh.write("这是一个测试文件,用于测试异常!!")
except IOError:
    print( "Error: 没有找到文件或读取文件失败")
else:
    print( "内容写入文件成功")
    fh.close()

在执行代码前为了测试方便,我们可以先去掉 testfile 文件的写权限,命令如下:
chmod -w testfile
 
 
再执行以上代码:
$ python test.py
Error: 没有找到文件或读取文件失败


使用except而不带任何异常类型
你可以不带任何异常类型使用except,如下实例:
try:
    正常的操作
   ......................
except:
    发生异常,执行这块代码
   ......................
else:


    如果没有异常执行这块代码
以上方式try-except语句捕获所有发生的异常。但这不是一个很好的方式,
我们不能通过该程序识别出具体的异常信息。因为它捕获所有的异常。


使用except而带多种异常类型
你也可以使用相同的except语句来处理多个异常信息,如下所示:
try:
    正常的操作
   ......................
except(Exception1[, Exception2[,...ExceptionN]]]):
   发生以上多个异常中的一个,执行这块代码
   ......................
else:
    如果没有异常执行这块代码


用户自定义异常
通过创建一个新的异常类,程序可以命名它们自己的异常。
异常应该是典型的继承自Exception类,通过直接或间接的方式。
以下为与RuntimeError相关的实例,实例中创建了一个类,
基类为RuntimeError,用于在异常触发时输出更多的信息。
在try语句块中,用户自定义的异常后执行except块语句,
变量 e 是用于创建Networkerror类的实例:

class Networkerror(RuntimeError):
    def __init__(self, arg):
        self.args = arg
 
 
在你定义以上类后,你可以触发该异常,如下所示:
try:
    raise Networkerror("Bad hostname")
except Networkerror,e:
    print e.args


 日志

 日志相关概念:用来记录程序中 重要的消息

 1.日志级别
 日志一共分成5个级别,从低到高分别是:DEBUG  INFO WARNING ERROR CRITICAL
 DEBUG:详细的信息,通常只出现在诊断问题上
 INFO:确认一切按预期运行
 WARNING:一个迹象表明,一些意想不到的事情发生了,
 或表明一些问题在不久的将来(例如:磁盘空间低)
 ERROR:更严重的问题,软件没能执行一些功能
 CRITICAL:一个严重的错误,这表明程序本身可能无法继续运行

 这五等级,也分别对应五种打开日志的方法: debug 、info 、warning 、error 、critical。
 默认的是WARNING,当在WARNING或之上时才被跟踪。


 2、日志输出
 有两种方式记录跟踪,一种输出控制台,另一种是记录到文件中,如日志文件。
import  logging
log_format='%(asctime)s- %(levelname)s- %(message)s'
DATE_FORMAT = "%Y-%m-%d"
logging.basicConfig(level=logging.DEBUG,
                    filename='my.log',
                    format=log_format,
                    datefmt=DATE_FORMAT)

logging.debug("this is a debug")
logging.info("this is a info")
logging.warning("this is a warning")
logging.error("this is a error")
logging.critical("this is a critical")

3.日志字段信息与日志格式
本节开始问题提到过,一条日志信息对应的是一个事件的发生,
而一个事件通常需要包括以下几个内容:
事件发生时间
事件发生位置
事件的严重程度--日志级别
事件内容







猜你喜欢

转载自blog.csdn.net/hwj990/article/details/80377266