python日志记录-logging模块
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模块使用问题和实例
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')
http://python.jobbole.com/84092/ [必看,深入浅出]
http://python.jobbole.com/82221/ [基础全面]
http://python.jobbole.com/81521/ [简单]
http://python.jobbole.com/81666/ [简单]
python日志记录-logging模块的更多相关文章
- Python日志输出——logging模块
Python日志输出——logging模块 标签: loggingpythonimportmodulelog4j 2012-03-06 00:18 31605人阅读 评论(8) 收藏 举报 分类: P ...
- Python的日志记录-logging模块的使用
一.日志 1.1什么是日志 日志是跟踪软件运行时所发生的事件的一种方法,软件开发者在代码中调用日志函数,表明发生了特定的事件,事件由描述性消息描述,同时还包含事件的重要性,重要性也称为级别或严重性. ...
- Python日志记录(Logging)
日志记录跟程序的测试相关,并且在大幅度更改程序内核时很有用,它可以帮助我们找到问题和错误的所在.日志记录基本上就是收集与程序运行有关的数据,这样可以在随后进行检查或者累计数据. 1.简单示例 在Pyt ...
- 日志记录——logging模块
Logging:日志记录是为了跟踪记录软件运行时,发生的事件,包括出错,提示信息等等.log日志级别:日志级别大小关系为:CRITICAL > ERROR > WARNING > I ...
- Python之日志处理 logging模块
Python之日志处理(logging模块) 本节内容 日志相关概念 logging模块简介 使用logging提供的模块级别的函数记录日志 logging模块日志流处理流程 使用logging四 ...
- Python实战之logging模块使用详解
用Python写代码的时候,在想看的地方写个print xx 就能在控制台上显示打印信息,这样子就能知道它是什么了,但是当我需要看大量的地方或者在一个文件中查看的时候,这时候print就不大方便了,所 ...
- Python中的logging模块就这么用
Python中的logging模块就这么用 1.日志日志一共分成5个等级,从低到高分别是:DEBUG INFO WARNING ERROR CRITICALDEBUG:详细的信息,通常只出现在诊断问题 ...
- 日志(logging模块)
1. 为什么要使用日志(作用) 在学习过程中,写一个小程序或小demo时,遇到程序出错时,我们一般会将一些信息打印到控制台进行查看,方便排查错误.这种方法在较小的程序中很实用,但是当你的程序变大,或是 ...
- Python自建logging模块
本章将介绍Python内建模块:日志模块,更多内容请从参考:Python学习指南 简单使用 最开始,我们用最短的代码体验一下logging的基本功能. import logging logger = ...
随机推荐
- Android系统环境变量配置
ANDROID_HOME D:\Program Files\Android-sdk D:\AndroidSDK\android-sdk ANDROID_SDK_HOME %ANDROID_HOME% ...
- 【Tomcat】项目自动部署的链接重置错误
在服务器中装好的tomcat7 ,(服务器是的window server 2008) 在tomcat bin目录运行的 service.bat install 安装服务.然后,设置服务项(服务项名称: ...
- NOPI使用手册
目录 1. 认识NPOI 2. 使用NPOI生成xls文件 2.1 创建基本内容 2.1.1 创建Workbook和Sheet 2.1.2 创建DocumentSummaryInformation和S ...
- MVC 使用PageList进行分页
1.新建MVC项目 2.在Web项目下添加PagedList nuget 命令 :install-package pagedlist.mvc 在安装完成之后,会在Content下添加PagedList ...
- Python同步数据库的数据到Neo4J
写了主要是步骤,如果疑问,请咨询QQ:5988628 Python版本采用2.7.X,默认的2.6.X后期会有问题,建议,一开始就升级Python.然后再安装pip. 访问数据库 sqlalchemy ...
- UVa 1583 - Digit Generator
A+A的每一位的数字的和=B 问你每一个B对应 的最小的A 是多少 不然输出0: #include <cstdio> #include <iostream> #include ...
- 下拉条的连动-ajax方式
客户端触发: <select id="category1" onchange="changecategory()"> <option v ...
- Linux定时任务Crontab命令详解
linux 系统则是由 cron (crond) 这个系统服务来控制的.Linux 系统上面原本就有非常多的计划性工作,因此这个系统服务是默认启动的.另 外, 由于使用者自己也可以设置计划任务,所以, ...
- C++多字节字符转换为宽字符的两种方法
目前知道有两种方式:可以提供宽字符与ANSI字符之间的转换, 第一种由COM库提供的函数 char* _com_util::ConvertBSTRToString(BSTR ); BSTR _com ...
- jquery validation plugin 使用
<!DOCTYPE html> <!-- To change this license header, choose License Headers in Project Prope ...