1、logging模块日志级别

使用logging模块简单示例:

>>>import logging
>>>logging.debug("this's a test logging")
>>>loggin.info("still a test logging")
# 默认情况下以上两行没有输出,需要指定日志级别才行
>>>logging.warn("it's waring!!!")

logging模块日志级别:

日志级别
CRITICAL 50
ERROR 40
WARNING 30
INFO 20
DEBUG 10
UNSET 0

对于某个级别的日志消息,只有当处理器和日志记录器配置为可以发布该级别(或者更高级别的消息时),才会发布这个日志消息。例如,如果一个消息的级别是CRITICAL,日志配置的级别是ERROR,这个消息就会发出(50>40)。如果这个消息是WARNING,而日志记录器设置为的是ERROR,这个消息就不会发出(30<40).

2、logging模块基本理解使用

  • 不同的优先级对应不同的函数:logging.debug,logging.warn等等

  • 一个或多个Logger对象,主要通过它们使用模块

  • 把消息写入终端或文件、数据库或其他地方的handler

  • 创建输出的formatter

  • 基于输入进行筛选的过滤器


一、设置logging日志默认优先级:

默认级别是WARNING,设置日志默认优先级为DEBUG
>>>import logging
>>>logging.basicConfig(level=logging.DEBUG)

二、创建logger对象

每个logger对象都有一个名称,比如创建一个test的logger
>>>import logging
>>>logging.basicConfig(level='DEBUG')
>>>logger = longgin.getLogger('test')
>>>logger.debug('the great gates!')
DEBUG:test:the great gates!

三、使用Handler把消息输出到日志文件

>>>import logging
>>>logging.basicConfig(level='DEBUG', filename='test.log')
>>>logger = logging.getLogger('tx')
>>>logger.war('xxxxssss')
日志写入了文件test.log,调用basicConfig()时使用的filename参数会创建一个FileHandler并对logger进行设置,logging模块至少包含15种handler,比如电子邮件、web服务器、屏幕和文件 

四、控制消息的格式

>>>import logging
>>>fmt = '%(asctime)s %(levelname)s %(lineno)s %(message)s'
>>>logging.basicConfig(lebel='DEBUG', filename='test.log', format=fmt)
>>>logger = logging.getLogger('xx')
>>>logger.warn('where is loggggg')
2016-5-5 23:22:11,877 WARN 1 where is loggggg
logging模块可以识别出fmt格式化字符串中的变量名,asctime、levelname、lineo、message,都是内置变量,也可以创建自定义变量。 

3、日志文件旋转

  • 要想每次运行程序的时候创建一个新文件,可以向basicConfig()的参数filemode传入值"w"。不过最好不要采用这种方式管理日志文件,更好的做法是使用一个RotatingFileHandler,它会自动创建新文件,同时保留原来的文件.

>>>import glob
>>>import logging
>>>import logging.handlers
>>>logger = logging.getLogger('mylogger')
>>>logger.setLevel(logging.DEBUG)
>>>log_filename='test.log'
>>>handler = logging.handlers.RotatingFileHandler(log_filename, maxBytes=100, backupCount=5)
>>>logger.addHandler(handler)
# 查看滚动生成的日志文件
for i in range(100):
logger.debug('i = %d' % i)
# 查看那些文件被创建
logfiles = glob.glob('%s *' % log_filename)
for filename in logfiles:
print filename
结果:
test.log
test.log.1
test.log.2
...
test.log.5
最新的文件总是test.log,每次达到大小限制时,就会后缀加.1重命名。现有的各个备份文件也会重命名,使后缀递增(.1变成.2,等等),.5文件会被删除

 4、logging模块使用问题和实例

1、logging模块中子类继承父类过程中,父类使用logging.basicConfig()进行的配置,会覆盖掉子类中的配置.所以子类中用logging.basicConfig()进行的配置不会生效.

2、另外使用logger=logging.getLogger()进行实例化对象过程中,如果是继承父类的,仍然不会生效,由于logging.getLogger()是以"."作为不同层级的区分.当子类需要另外设置logging的配置时,要另外通过设置handler的方式,来避免父类的logging配置掩盖子类.

3、具体首先配置logger = logging.getLogger(__name__) "__name__"不能为空,为其他的参数也可以,如果为logger=logging.getLogger(),似乎子类配置的logger不会生效.

增加handler:
log_file = './test.log'
fmt = fmt = '%(asctime)s %(filename)s %(funcName)s %(levelname)s Line:%(lineno)s :%(message)s'
logger = logging.getLogger(__name__)
logger.level = logging.DEBUG
handlers = logging.FileHandler(log_file)
formatter = logging.Formatter(fmt)
handlers.formatter = formatter
loggers.addHandler(handlers) 使用logger:
logger.info('it's a test')
4、其logging模块参考文档:
http://python.jobbole.com/84092/  [必看,深入浅出]
http://python.jobbole.com/82221/   [基础全面]
http://python.jobbole.com/81521/   [简单]
http://python.jobbole.com/81666/   [简单]

python日志记录-logging模块的更多相关文章

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

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

  2. Python的日志记录-logging模块的使用

    一.日志 1.1什么是日志 日志是跟踪软件运行时所发生的事件的一种方法,软件开发者在代码中调用日志函数,表明发生了特定的事件,事件由描述性消息描述,同时还包含事件的重要性,重要性也称为级别或严重性. ...

  3. Python日志记录(Logging)

    日志记录跟程序的测试相关,并且在大幅度更改程序内核时很有用,它可以帮助我们找到问题和错误的所在.日志记录基本上就是收集与程序运行有关的数据,这样可以在随后进行检查或者累计数据. 1.简单示例 在Pyt ...

  4. 日志记录——logging模块

    Logging:日志记录是为了跟踪记录软件运行时,发生的事件,包括出错,提示信息等等.log日志级别:日志级别大小关系为:CRITICAL > ERROR > WARNING > I ...

  5. Python之日志处理 logging模块

    Python之日志处理(logging模块)   本节内容 日志相关概念 logging模块简介 使用logging提供的模块级别的函数记录日志 logging模块日志流处理流程 使用logging四 ...

  6. Python实战之logging模块使用详解

    用Python写代码的时候,在想看的地方写个print xx 就能在控制台上显示打印信息,这样子就能知道它是什么了,但是当我需要看大量的地方或者在一个文件中查看的时候,这时候print就不大方便了,所 ...

  7. Python中的logging模块就这么用

    Python中的logging模块就这么用 1.日志日志一共分成5个等级,从低到高分别是:DEBUG INFO WARNING ERROR CRITICALDEBUG:详细的信息,通常只出现在诊断问题 ...

  8. 日志(logging模块)

    1. 为什么要使用日志(作用) 在学习过程中,写一个小程序或小demo时,遇到程序出错时,我们一般会将一些信息打印到控制台进行查看,方便排查错误.这种方法在较小的程序中很实用,但是当你的程序变大,或是 ...

  9. Python自建logging模块

    本章将介绍Python内建模块:日志模块,更多内容请从参考:Python学习指南 简单使用 最开始,我们用最短的代码体验一下logging的基本功能. import logging logger = ...

随机推荐

  1. Android系统环境变量配置

    ANDROID_HOME D:\Program Files\Android-sdk D:\AndroidSDK\android-sdk ANDROID_SDK_HOME %ANDROID_HOME% ...

  2. 【Tomcat】项目自动部署的链接重置错误

    在服务器中装好的tomcat7 ,(服务器是的window server 2008) 在tomcat bin目录运行的 service.bat install 安装服务.然后,设置服务项(服务项名称: ...

  3. NOPI使用手册

    目录 1. 认识NPOI 2. 使用NPOI生成xls文件 2.1 创建基本内容 2.1.1 创建Workbook和Sheet 2.1.2 创建DocumentSummaryInformation和S ...

  4. MVC 使用PageList进行分页

    1.新建MVC项目 2.在Web项目下添加PagedList nuget 命令 :install-package pagedlist.mvc 在安装完成之后,会在Content下添加PagedList ...

  5. Python同步数据库的数据到Neo4J

    写了主要是步骤,如果疑问,请咨询QQ:5988628 Python版本采用2.7.X,默认的2.6.X后期会有问题,建议,一开始就升级Python.然后再安装pip. 访问数据库 sqlalchemy ...

  6. UVa 1583 - Digit Generator

    A+A的每一位的数字的和=B 问你每一个B对应 的最小的A 是多少 不然输出0: #include <cstdio> #include <iostream> #include ...

  7. 下拉条的连动-ajax方式

    客户端触发: <select id="category1" onchange="changecategory()">    <option v ...

  8. Linux定时任务Crontab命令详解

    linux 系统则是由 cron (crond) 这个系统服务来控制的.Linux 系统上面原本就有非常多的计划性工作,因此这个系统服务是默认启动的.另 外, 由于使用者自己也可以设置计划任务,所以, ...

  9. C++多字节字符转换为宽字符的两种方法

    目前知道有两种方式:可以提供宽字符与ANSI字符之间的转换, 第一种由COM库提供的函数 char*  _com_util::ConvertBSTRToString(BSTR ); BSTR _com ...

  10. jquery validation plugin 使用

    <!DOCTYPE html> <!-- To change this license header, choose License Headers in Project Prope ...