昨天的任务是需要记录各操作的性能数据,所以需要用这种格式来输出日志:{"adb_start_time": 1480040663, "tag_name": "CLIMB_TOWER_8", "adb_end_time": 1480040767, "case_status": 0}
开始时间、操作名称、结束时间、运行结果("0": "成功","1": "失败","2": "异常")。于是简单的学习了一下日志输出:

一. 使用Python标准库——logging

1. 日志级别

日志一共分为5个级别:DEBUG<INFO<WARNING<ERROR<CRITICAL,分别对应logging的五个方法:debug、info、warning、error、critical。默认的是WARNING,当在WARNING或以上级别时,才会被跟踪。有两种方式记录跟踪:1)输出到控制台;2)记录到文件中,如日志文件

2. 日志组件

日志组件包括:logger、handler、filters、formatters

1. logger:主要扮演了三个角色:1)暴露给应用五个方法(debug..)以便应用在运行时写log;2)logger对象 按照log信息的严重程度或根据filter对象来决定如何处理log信息(默认的过滤功能);3)还负责把log信息传送给相关的loghandlers

2. handler:负责分配合适的log信息(基于log信息的严重程度)到handler指定的目的地。logger对象可以用addhandler()方法添加零个或多个handler对象。

例如:一个应用既可以将所有的log信息发送到一个log文件,所有的ERROR信息发送到stdout,所有的CRITICAL信息通过邮件发送,这里需要三个不同的Handler,每个Handler负责把特定的信息发送到特定的地方。

3. filter:过滤,确定哪些日志输出

4. formatter:设置显示格式

先看一个最简单的例子

  1. # 1. 创建logger
  2. logger = logging.getLogger(“sbw”)
  3.  
  4. # 2. 设置输入到日志文件
  5. logging.basicConfig(filename="../mylog.log",
  6. level=flevel,
  7. format="%(asctime)s %(levelname)s %(funcName)s %(message)s")
  8.  
  9. # 3. 终端Handler——输出到控制台
  10. consoleHandler = logging.StreamHandler()
  11. consoleHandler.setLevel(clevel)
  12.  
  13. # 定义Handle的格式
  14. formatter = logging.Formatter("%(asctime)s %(levelname)s %(funcName)s %(message)s")
  15.  
  16. # 给Handle添加formatter
  17. consoleHandler.setFormatter(formatter)
  18.  
  19. # 给logger添加handler
  20. self.logger.addHandler(consoleHandler)

对于日志记录,还可以使用logging.FileHandler:

  1. import logging
  2.  
  3. # 1、创建一个logger
  4. logger = logging.getLogger('mylogger')
  5. logger.setLevel(logging.DEBUG)
  6.  
  7. # 2、创建一个handler,用于写入日志文件
  8. fh = logging.FileHandler('test.log')
  9. fh.setLevel(logging.DEBUG)
  10.  
  11. # 3、定义handler的输出格式(formatter)
  12. formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
  13.  
  14. # 4、给handler添加formatter
  15. fh.setFormatter(formatter)
  16.  
  17. # 5、给logger添加handler
  18. logger.addHandler(fh)

典型的记录流程:

  1. 创建logger
  2. 创建handler
  3. 定义formatter
  4. 给handler添加formatter
  5. 给logger添加handler

3. logger

日志记录的工作主要是由Logger对象来完成的

3.1 创建logger——logging.getLogger([name])

在调用getLogger时需要提供Logger名称(如果多次使用相同的名称来调用getLogger,返回的是同一个对象的引用)。Logger实例之间有层次关系,名字中使用点号来进行等级管理,例如:

  1. p = logging.getLogger("root")
  2. c1 = logging.getLogger("root.c1")
  3. c2 = logging.getLogger("root.c2")

例子中,p是父logger, c1,c2分别是p的子logger。c1, c2将继承p的设置。如果省略了name参数, getLogger将返回日志对象层次关系中的根Logger。如果logger有父类,日志流会同时发送给logger和logger的父类的handler。

最好的方式,用:logging.getLogger("__name__"):

3.2 Logger方法

  1. logger.setLevel():设置日志的级别。对于低于该级别的日志消息将被忽略。
  2. logger.addHandler():添加handler;logger.remoteHandler():删除handler
  3. logger.addFilter():添加filter;logger.remoteHandler():删除filter
  4. logger.debug()、logger.info()、logger.warning()、logger.error()、logger.critical():记录日志
  5. logger.log(level, msg):logger.log(Logging.WARN, 'msg')==logging.warn('msg')

3.3 Logger属性

  • Logger.handlers 该logger已添加的Handlers
  • Logger.filters 该logger已添加的Filters
  • 获取Logger实例:getLogger() 来获取logger。

4. Handler

一个logger可以设置0个或以上的Handler。logger执行记录日志的方法后,会把日志交给Handler来处理。

4.1 Handler方法

  1. Handler.setLevel() 设置logger的日志严重程度
  2. Handler.addFilter,Handler.remoteFilter()添加或删除Filter
  3. setFormatter() 设置日志输出的格式

4.2 Handler类

1. logging.StreamHandler()

输出日志到一个文件对象,可以是open打开的文件,也可以是系统终端,例如sys.stdout或sys.stderr。

  1. # 1. 将日志输出到一个文件
  2. file = open('./test.log', 'w')
  3. fileHandler = logging.StreamHandler(file)
  4.  
  5. # 2. 输出到控制台(默认是:sys.stderr)
  6. consoleHandler = logging.StreamHandler()
  7. # 或者:
  8. consoleHandler2=logging.StreamHandler(sys.stdout)

2. logging.FileHandler(filename[, mode])

向一个文件中输出日志内容。如果文件根路径不存在,会报错。如果文件根路径存在,但是文件不存在,会自动创建文件。

  • filename是日志文件路径。
  • mode是写文件的方法,例如’a','w',参考open里面的mode

3. logging.handlers.RotatingFileHandler

类似FileHandler,不同的是这个可以管理文件的大小,如果日志文件大于某个值,就会把旧的日志重命名,并创建新的日志文件。如果有三个日志文件chat.log,chat.log.1,chat.log.2 ,时间大小:chat.log>chat.log.1>chat.log.2

  1. RotatingFileHandler( filename[, mode[, maxBytes[, backupCount]]])
  2. # 其中:
  3. # filename和mode两个参数和FileHandler一样。
  4. # maxBytes 最大文件大小,单位字节,0代表无限大。
  5. # backupCount 保留的备份个数。

例如:

  1. # 日志回滚
  2. import logging
  3. from logging.handlers import RotatingFileHandler
  4.  
  5. RtHandler = RotatingFileHandler("../mylog.log", maxBytes=20 * 1024 * 1024, backupCount=5)
  6. RtHandler.setLevel(logging.DEBUG)
  7. formatter = logging.Formatter("%(asctime)s %(levelname)s %(funcName)s %(message)s")
  8. RtHandler.setFormatter(formatter)
  9. self.logger.addHandler(RtHandler)

4. logging.handlers.TimedRotatingFileHandler

这个Handler和RotatingFileHandler类似,不同的是这个Handler通过时间来切分日志文件:

  1. TimedRotatingFileHandler( filename [,when [,interval [,backupCount]]])

其中filename参数和backupCount参数和RotatingFileHandler具有相同的意义

  • interval是时间间隔。
  • when参数是一个字符串。表示时间间隔的单位,不区分大小写。它有以下取值:
    S 秒
    M 分
    H 小时
    D 天
    W 每星期(interval==0时代表星期一)
    midnight 每天凌晨

5. 其他

5. logging.handlers.SocketHandler

6. logging.handlers.DatagramHandler
以上两个Handler类似,都是将日志信息发送到网络。不同的是前者使用TCP协议,后者使用UDP协议。它们的构造函数是:

  • Handler(host, port)

其中host是主机名,port是端口名

7. logging.handlers.SysLogHandler

8. logging.handlers.NTEventLogHandler

9. logging.handlers.SMTPHandler

10. logging.handlers.MemoryHandler

11. logging.handlers.HTTPHandler

5. Formatter

设置格式

二、使用配置:

Python 日志输出的更多相关文章

  1. Python日志输出——logging模块

    Python日志输出——logging模块 标签: loggingpythonimportmodulelog4j 2012-03-06 00:18 31605人阅读 评论(8) 收藏 举报 分类: P ...

  2. Python 日志输出中添加上下文信息

    Python日志输出中添加上下文信息 除了传递给日志记录函数的参数(如msg)外,有时候我们还想在日志输出中包含一些额外的上下文信息.比如,在一个网络应用中,可能希望在日志中记录客户端的特定信息,如: ...

  3. python日志输出

    import logging logger = logging.getLogger() #生成一个日志对象,()内为日志对象的名字,可以不带,名字不给定就是root,一般给定名字,否则会把其他的日志输 ...

  4. 修改Python文件日志输出位置

    Python logging模块介绍:http://blog.chinaunix.net/uid-26000296-id-4372063.html [root@fuel ~]# vi /var/lib ...

  5. Python之向日志输出中添加上下文信息

    除了传递给日志记录函数的参数(如msg)外,有时候我们还想在日志输出中包含一些额外的上下文信息.比如,在一个网络应用中,可能希望在日志中记录客户端的特定信息,如:远程客户端的IP地址和用户名.这里我们 ...

  6. 【转】Python之向日志输出中添加上下文信息

    [转]Python之向日志输出中添加上下文信息 除了传递给日志记录函数的参数(如msg)外,有时候我们还想在日志输出中包含一些额外的上下文信息.比如,在一个网络应用中,可能希望在日志中记录客户端的特定 ...

  7. 浅析python日志重复输出问题

    浅析python日志重复输出问题 问题起源: ​ 在学习了python的函数式编程后,又接触到了logging这样一个强大的日志模块.为了减少重复代码,应该不少同学和我一样便迫不及待的写了一个自己的日 ...

  8. python的日志模块:logging;django的日志系统;django日志输出时间修改

    Django的log,主要是复用Python标准库中的logging模块,在settings.py中进行配置 源代码 1.__init__.py包含以下类: StreamHandler Formatt ...

  9. python日志模块logging

    python日志模块logging   1. 基础用法 python提供了一个标准的日志接口,就是logging模块.日志级别有DEBUG.INFO.WARNING.ERROR.CRITICAL五种( ...

随机推荐

  1. php5.5过渡--mysql连接

    以前: // $conn=mysql_connect("localhost","root","");// $db=mysql_select_ ...

  2. js下载文件

    本文的前提是:后台给的是一个可以下载的url的情况下的下载: 怎样的文件url才能触发浏览器的下载行为?(转自SF) 能触发浏览器下载的url有两类: response header中指定了Conte ...

  3. 关于session销毁的问题,invalidate() 和removeAttribute()

    request.getSession().invalidate(); 销毁当前会话域中的所有属性 request.getSession().removeAttribute("username ...

  4. JavaScript 常见面试题

    此文内容多为 JavaScript 对数组理解及运用. 1.如何消除一个数组里面重复的元素? var arr = [1, 2, 3, 3, 4, 4, 5, 5, 6, 1]; var newArr ...

  5. JS 面试题 实践一

    1.完成 extname 函数,它会接受一个文件名作为参数,你需要返回它的扩展名. 例如,输入 emoji.png,返回 .png. const extname = (filename) => ...

  6. opencv3.2.0实现读取多张图片的方法(利用sprintf()函数)

    简介: 将连续的图片转换成视频时,首先需要把图片全部读入,然后再做相应处理,该程序利用sprintf()函数,实现连续图片的读入 /*********新建QT控制台程序,实现多张连续图片的读取**** ...

  7. Android MVP Plugin,一键完成MVP结构代码编写

    推荐一个Gradle的学习系列,Gradle相关的知识一直很匮乏,难得发现一个不错的系列: http://www.cnblogs.com/davenkin/p/gradle-learning-1.ht ...

  8. spring boot(9)-mybatis关联映射

    一对多 查询type表的某一条数据,并且要同时查出所有typeid与之配置的user,最终要得到一个以下类型的Type对象 public class Type { String id; String ...

  9. mysqlcilent的安装

    这软件包是贼的气 首先是windows的安装上你必须要指定版本,linux的安装你就不需要指定版本了 windos上的指定安装必须要   一.下载包的时候需要指定版本, 比如python2的和mysq ...

  10. 山寨Facebook的Shimmer效果

    山寨Facebook的Shimmer效果 说明 主要是用到了CAGradientLayer的特性来实现特效效果,因为时间有限,并没有进行封装,待后续改进. 效果 源码(源码没有进行封装,细节都没有处理 ...