python中Exception异常处理

 代码如下 复制代码

一、异常的捕获
    异常的捕获有以下几种方法:
  

  1:使用try和except语句

    try:
        block
    except [exception,[data…]]:
        block
    try:
        block
    except [exception,[data...]]:
        block
    else:
        block

该种异常处理语法的规则是:
• 执行try下的语句,如果引发异常,则执行过程会跳到第一个except语句。
• 如果第一个except中定义的异常与引发的异常匹配,则执行该except中的语句。
• 如果引发的异常不匹配第一个except,则会搜索第二个except,允许编写的except数量没有限制。
• 如果所有的except都不匹配,则异常会传递到下一个调用本代码的最高层try代码中。
• 如果没有发生异常,则执行else块代码。
示例代码:

   

try:
        f = open(“file.txt”,”r”)
    except IOError, e:
        print e

    捕获到的IOError错误的详细原因会被放置在对象e中,然后运行该异常的except代码块,也可以使用以下方法来捕获所有的异常:

  

  try:
        a=b
        b=c
    except Exception,ex:
        print Exception,":",ex

 

    使用except子句需要注意的事情,就是多个except子句截获异常时,如果各个异常类之间具有继承关系,则子类应该写在前面,否则父类将会直接截获子类异常,放在后面的子类异常也就不会执行到了。

    2:使用try跟finally

 

   try:
        block
    finally:
        block

该语句的执行规则是:
• 执行try下的代码。
• 如果发生异常,在该异常传递到下一级try时,执行finally中的代码。
• 如果没有发生异常,则执行finally中的代码。

    第二种try语法在无论有没有发生异常都要执行代码的情况下是很有用的,例如我们在python中打开一个文件进行读写操作,我在操作过程中不管是否出现异常,最终都是要把该文件关闭的。
    这两种形式相互冲突,使用了一种就不允许使用另一种,而功能又各异。

    二、手工引发引发一个异常
    在Python中,要想引发异常,最简单的形式就是输入关键字raise,后跟要引发的异常的名称。异常名称标识出具体的类:Python异常是那些类的对象,执行raise语句时,Python会创建指定的异常类的一个对象,raise语句还可指定对异常对象进行初始化的参数,为此,请在异常类的名称后添加一个逗号以及指定的参数(或者由参数构成的一个元组)。
示例代码:

 

   try:
        raise MyError #自己抛出一个异常
    except MyError:
        print 'a error'
    raise ValueError,'invalid argument'

捕捉到的内容为:

 

   type = VauleError
    message = invalid argument

 

    三、跟踪查看异常
    发生异常时,Python能“记住”引发的异常以及程序的当前状态,Python还维护着traceback(跟踪)对象,其中含有异常发生时与函数调用堆栈有关的信息,异常可能在一系列嵌套较深的函数调用中引发,程序调用每个函数时,Python会在“函数调用堆栈”的起始处插入函数名,一旦异常被引发,Python会搜索一个相应的异常处理程序。
    如果当前函数中没有异常处理程序,当前函数会终止执行,Python会搜索当前函数的调用函数,并以此类推,直到发现匹配的异常处理程序,或者Python抵达主程序为止,这一查找合适的异常处理程序的过程就称为“堆栈辗转开解”(Stack Unwinding)。解释器一方面维护着与放置堆栈中的函数有关的信息,另一方面也维护着与已从堆栈中“辗转开解”的函数有关的信息。

 

   try:
        block
    except:
        traceback.print_exc()

    四、采用sys模块回溯最后的异常

    import sys
    try:
        block
    except:
        info=sys.exc_info()
        print info[0],":",info[1]

或者以如下的形式:

   

import sys
        tp,val,td = sys.exc_info()

    sys.exc_info()的返回值是一个tuple, (type, value/message, traceback)
    这里的type是异常的类型,value/message是异常的信息或者参数,traceback包含调用栈信息的对象,从这点上可以看出此方法涵盖了traceback。

    以上都是错误处理的理论知识,接下来我们要动手设计一个自己的异常处理类,用来记录异常日志,将错误的日志按照每小时一个文件的频率,保存到我们指定的位置。代码如下:

    #coding:utf-8
    #基于python2.6
    import logging,os,time,traceback
    class LOG:
        def __init__(self,logger):
            self.fileHandlerName = ''
            self.fileHandler = None
            self.loggerName = logger
            self.logger = logging.getLogger(logger)
            self.logger.setLevel(logging.DEBUG)
            self.formatter = logging.Formatter("=========================ntime:%(asctime)s nlogger:%(name)s nlevel:%(levelname)s nfile:%(filename)s nfun:%(funcName)s nlineno:%(lineno)d nmessage:%(message)s")
            # 控制台
            ch = logging.StreamHandler()
            ch.setLevel(logging.DEBUG)
            ch.setFormatter(self.formatter)
            self.logger.addHandler(ch)
            path = os.path.abspath(os.path.dirname(__file__)) + '/log/'+self.loggerName+'/'
            print 'log path=',path
       
        def setfh(self):
            fname = time.strftime("%Y%m%d%H")
            if fname!=self.fileHandlerName:
                #移除原来的句柄
                if self.fileHandler!=None :
                    self.logger.removeHandler(self.fileHandler)
                #设置日志文件保存位置
                path = os.path.abspath(os.path.dirname(__file__)) + '/log/'+self.loggerName+'/'
                print path
                if os.path.isdir(path) == False:
                    os.makedirs(path)
                fh = logging.FileHandler(path+fname+'.log')
                fh.setLevel(logging.DEBUG)
                fh.setFormatter(self.formatter)
                self.logger.addHandler(fh)
                self.fileHandlerName = fname
                self.fileHandler = fh
        #格式化日志内容
        def _fmtInfo(self,msg):
            if len(msg)==0:
                msg = traceback.format_exc()
                return msg
            else:
                _tmp = [msg[0]]
                _tmp.append(traceback.format_exc())
                return 'n**********n'.join(_tmp)
        #封装方法
        def debug(self,*msg):
            _info = self._fmtInfo(msg)
            try:
                self.setfh()
                self.logger.debug(_info)
            except:
                print 'mylog debug:' + _info
        def error(self,*msg):
            _info = self._fmtInfo(msg)
            try:
                self.setfh()
                self.logger.error(_info)
            except:
                print 'mylog error:' + _info
        def info(self,*msg):
            _info = self._fmtInfo(msg)
            try:
                self.setfh()
                self.logger.error(_info)
            except:
                print 'mylog info:' + _info
        def warning(self,*msg):
            _info = self._fmtInfo(msg)
            try:
                self.setfh()
                self.logger.error(_info)
            except:
                print 'mylog warning:' + _info
           
    if __name__=='__main__':
        log = LOG('fight')
        try:
            print 1/0
        except:
            log.error() #使用系统自己的错误描述
        try:
            print 2/0
        except:
            log.error('搞错了,分母不能为0') #使用自己的错误描述

时间: 2024-09-21 11:27:14

python中Exception异常处理的相关文章

Python中的异常处理

  这篇文章主要介绍了解析Python中的异常处理,异常处理是学习每门编程语言都必须掌握的重要知识,本文代码基于Python2.x版本,需要的朋友可以参考下 在程序运行的过程中,如果发生了错误,可以事先约定返回一个错误代码,这样,就可以知道是否有错,以及出错的原因.在操作系统提供的调用中,返回错误码非常常见.比如打开文件的函数open(),成功时返回文件描述符(就是一个整数),出错时返回-1. 用错误码来表示是否出错十分不便,因为函数本身应该返回的正常结果和错误码混在一起,造成调用者必须用大量的

PHP中Exception异常处理类的使用详解

 代码如下 复制代码 <?php     try {         $a=10/0;     }catch (Exception $e){         echo "抛出异常";     } ?> 以上代码,并不会输出"抛出异常",而是输出了错误信息:Warning: Division by zero in...... 说明:try块中并没有抛出异常,而是按照系统默认的错误处理机制进行处理 所以能不能捕获到异常,取决于有没有真正的抛出异常    代码

Python中的异常处理学习笔记_python

Python 是面向对象的语言,所以程序抛出的异常也是类. 常见的异常类 1.NameError:尝试访问一个没有申明的变量 2.ZeroDivisionError:除数为 0 3.SyntaxError:语法错误 4.IndexError:索引超出序列范围 5.KeyError:请求一个不存在的字典关键字 6.IOError:输入输出错误(比如你要读的文件不存在) 7.AttributeError:尝试访问未知的对象属性 8.TypeError:传给函数的参数类型不正确,比如给 int 函数传

Python中的异常处理简明介绍_python

python异常处理机制和java类似,采用try-except-finally的结构. try-except检测异常 格式 复制代码 代码如下: try:     try_statement except (ErrorType1, ErrorType2),e:     handle_statement finally:     finally_statement 实例 复制代码 代码如下: #!/usr/bin/python try:     a=12     b=0     c = a/b

Python中使用异常处理来判断运行的操作系统平台方法_python

代码实例: 复制代码 代码如下: try:     import termios, TERMIOS 1 except ImportError:     try:         import msvcrt 2     except ImportError:         try:             from EasyDialogs import AskPassword 3         except ImportError:             getpass = "default

python中的五种异常处理机制介绍_python

从几年前开始学习编程直到现在,一直对程序中的异常处理怀有恐惧和排斥心理.之所以这样,是因为不了解.这次攻python,首先把自己最畏惧和最不熟悉的几块内容列出来,里面就有「异常处理」这一项. <Dive into Python>并没有专门介绍异常处理,只是例子中用到的时候略微说明了一下.今天下载<Learn Python>,直接进异常处理这块.这一部分有四章,第一章讲解异常处理的一般使用方法,后面的章节深入地讨论其机制.我目前只看了第一章,先学会用,以后有必要的时候再扩展阅读. p

Python中的日志模块logging

  这篇文章主要介绍了Python中的日志模块logging,包括Python下的日志级别以及模块内常用方法的使用,需要的朋友可以参考下 许多应用程序中都会有日志模块,用于记录系统在运行过程中的一些关键信息,以便于对系统的运行状况进行跟踪.在.NET平台中,有非常著名的第三方开源日志组件log4net,c++中,有人们熟悉的log4cpp,而在python中,我们不需要第三方的日志组件,因为它已经为我们提供了简单易用.且功能强大的日志模块:logging.logging模块支持将日志信息保存到不

Python&amp;amp;nbsp;异常处理

Python 异常处理 python提供了两个非常重要的功能来处理python程序在运行中出现的异常和错误.你可以使用该功能来调试python程序. 异常处理: 本站Python教程会具体介绍. 断言(Assertions):本站Python教程会具体介绍. python标准异常 异常名称 描述 BaseException 所有异常的基类 SystemExit 解释器请求退出 KeyboardInterrupt 用户中断执行(通常是输入^C) Exception 常规错误的基类 StopIter

Python进阶08 异常处理

原文:Python进阶08 异常处理 作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 本文特别感谢kylinfish的纠正,相关讨论见留言区.   异常处理 在项目开发中,异常处理是不可或缺的.异常处理帮助人们debug,通过更加丰富的信息,让人们更容易找到bug的所在.异常处理还可以提高程序的容错性. 我们之前在讲循环对象的时候,曾提到一个StopIteration的异常,该异常是在循环对象穷尽所有元素时的报错. 我们以它为