Python的异常处理能力是很强大的,可向用户准确反馈出错信息。在Python中,异常也是对象,可对它进行操作。所有异常都是基类Exception的成员,所有异常都从基类Exception继承,而且都在exceptions模块中定义,Python自动将所有异常名称放在内建命名空间中,所以程序不必导入exceptions模块即可使用异常。

一旦引发而且没有捕捉SystemExit异常,程序执行就会终止。如果交互式会话遇到一个未被捕捉的SystemExit异常,会话就会终止。

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

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')

#使用自己的错误描述

运行一下,我们会在该文件目录下的log/fight下看到一个日志文件

python中用来回溯异常的模块_python中的异常处理使用说明相关推荐

  1. python中用来回溯异常的模块_python学习笔记(异常)

    什么是异常 python用异常对象(exception object)来表示异常情况.遇到错误后,会引发异常.如果异常对象并未被处理或捕捉,程序就会用所谓的 回溯(Traceback, 一种错误信息) ...

  2. python中用来回溯异常的模块_为什么Python线缓存会影响回溯模块而不影响...

    考虑以下Python程序: code = """ def test(): 1/0 """ filename = "" c ...

  3. python中用来回溯异常的模块_Python_10-异常处理

    目录: 1.1 python标准异常 1.2简介 1.3 try语句 1.3.1使用try和except语句来捕获异常 1.3.2该种异常处理语法的规则 1.3.3使用try跟finally 1.4用 ...

  4. python解析html xml最好的模块_python中处理xml的模块哪个好?

    python中可以使用BeautifulSoup4或pyQuery模块处理xml文件.pyQuery模块比较适合于对CSS选择器等的支持,BeautifulSoup4模块使用简单. Beautiful ...

  5. python中用来抛出异常的关键字是( )_python异常抛出

    广告关闭 腾讯云11.11云上盛惠 ,精选热门产品助力上云,云服务器首年88元起,买的越多返的越多,最高返5000元! 主动抛出异常raise typeerror(类型错误) # 7. 触发异常try ...

  6. Python基础之 8. 异常、模块

    1. 异常 1. 异常介绍 demo:打开一个不存在的文件123.txt,当找不到123.txt 文件时,就会抛出给我们一个IOError类型的错误,No such file or directory ...

  7. python从包中导入模块_Python中包,模块导入的方法

    Python中包,模块导入的方法 http://www.cnblogs.com/allenblogs/archive/2011/05/24/2055149.html 1. import modname ...

  8. python中用来抛出异常的关键字是( )_python如何抛出异常

    异常是Python对象,表示一个错误. 当Python脚本发生异常时我们需要捕获处理它,否则程序会终止执行. python学习网,大量的免费python视频教程,欢迎在线学习! 常见异常# Attri ...

  9. Python面向对象进阶与异常、模块以及包管理

    这一篇是面向对象的进阶部分,主要还是面向对象的封装,继承,多态方面的讲解,后面的部分是讲解python异常和模块以及包的部分. 目录 一.Python中的继承 1.什么是继承 2.继承的基本语法 3. ...

最新文章

  1. [ 浙江大学 程序设计专题 ] 四个专题代码 报告 PPT共享
  2. JavaScript数组随机排序
  3. WPF中实现文件夹对话框(OpenFileDialog in WPF)
  4. 1.10.Flink DataStreamAPI(API的抽象级别、Data Sources、connectors、Source容错性保证、Sink容错性保证、自定义sink、partition等)
  5. pyqt5子窗口跳出主窗口_弹出式窗口与 可用性,转换和跳出率
  6. python-描述符的分类
  7. Node 实现 AES 加密,结果输出为“byte”。
  8. vue是否可以做行车轨迹_在vue中高德地图引入和轨迹的绘制的实现
  9. 方法超出 android,Android工程方法数超过64k,The number of method references in a .dex file cannot exceed 64K....
  10. oracle yum 本地源,Linux YUM本地源配置
  11. 三元运算符(Java)
  12. ABP框架详解(一)ABPBootstrapper
  13. 大神带你实现 NLP 从入门到获奖,还有免费算力可以薅
  14. ZZULIOJ:1059: 最高分
  15. tlsf算法-概念、原理、内存碎片问题分析
  16. python批量读取tiff文件_Python Pillow批量转换tif格式到jpg
  17. 如何查看手机上已连接 WIFI 的密码
  18. wildcard函数
  19. 在Excel中如何把每三行数据合并为一行?
  20. 关于惠普打印机驱动解压时候出现的问题

热门文章

  1. boost::variant2模块实现默认构造相关的测试程序
  2. boost::spirit模块实现演示语法的普通计算器示例
  3. boost::range模块实现map_keys相关的测试程序
  4. boost::multi_array模块测试 index_gen 的代码
  5. boost::histogram::axis::circular用法的测试程序
  6. boost::contract模块实现name list名单的测试程序
  7. 使用Boost.Compute的STL 在GPU上添加两个向量的实现
  8. DCMTK:将XML文档转换为DICOM文件或数据集
  9. VTK:可视化之ProjectSphere
  10. VTK:可视化之BackgroundColor