python的日志模块为logging,它可以将我们想要的信息输出保存到一个日志文件中。

# cat log
import logging logging.debug('This is debug message')
logging.info('This is info message')
logging.warning('This is warring message')
# python log
WARNING:root:This is warring message

默认情况下,logging将日志打印到屏幕,日志级别为WARRING。

日志级别的关系为:CRITICAL》ERROR》WARNING》INFO》DEBUG》NOTEST,可自定义日志级别。

二、通过logging.basicConfig函数对日志的输出格式及方式做相关配置

root@web01:/srv/stackinsider-org/stack/log/logtest# cat log
import logging logging.basicConfig(
level=logging.DEBUG, #日志级别,默认为logging.WARNING
format='%(asctime)s %(filename)s [line:%(lineno)d] %(levelname)s %(message)s',
datefmt='%a, %d %b %Y %H:%M:%S', #指定时间格式
filename='lxy.log', #日志文件名,没有会自动生成
filemode='w' #覆盖之前log
) logging.debug('This is debug message')
logging.info('This is info message')
logging.warning('This is warring message') 日志文件内容如下【如果没有会自动生成】
# cat lxy.log
Thu, 12 Mar 2015 10:13:43 log [line:11] DEBUG This is debug message
Thu, 12 Mar 2015 10:13:43 log [line:12] INFO This is info message
Thu, 12 Mar 2015 10:13:43 log [line:13] WARNING This is warring message

logging.basicConfig函数各参数:

filename:指定日志文件名

filemode:和file函数意义相同,指定日志文件的打开模式,'w'或者'a'。

level:设置日志级别,默认为logging.WARNING。

datafmt:指定日志格式,同time.strftime()

stream:指定日志的输出流,可以指定输出到sys.stderr,sys.stdout或者文件,默认输出到sys.stderr,当stream和filename同时指定时,stream被忽略。

format:指定输出的格式和内容,format可以输出很多有用信息:

%(levelno)s:打印日志级别的数值

%(levelname)s:打印日志级别名称

%(pathname)s:打印当前知悉程序的路径,其实就是sys.argv[0]

%(filename)s:打印当前执行程序名

%(funcName)s:打印日志当前函数

%(lineno)d:打印日志的当前行号

%(asctime)s:打印日志的时间

%(thread)d:打印线程ID

%(threadName)s:打印线程名称

%(process)d:打印进程ID

%(message)s:打印日志信息

三、将日志同时输出到文件和屏幕

# cat log
import logging logging.basicConfig(
level=logging.DEBUG,
format='%(asctime)s %(filename)s [line:%(lineno)d] %(levelname)s %(message)s',
datefmt='%a, %d %b %Y %H:%M:%S',
filename='lxy.log',
filemode='w'
)
#定义一个StreamHandler,将INFO级别或更高级别的日志信息打印到标准错误,并将其添加到当前的日志处理对象
console=logging.StreamHandler()
console.setLevel(logging.INFO)
#控制台输出格式,8s代表8个空格
formatter=logging.Formatter('%(name)-8s: %(levelname)-8s %(message)s')
console.setFormatter(formatter)
logging.getLogger('').addHandler(console)
#log信息写入日志文件
logging.debug('This is debug message')
logging.info('This is info message')
logging.warning('This is warring message') # python log
#控制台输出
root : INFO This is info message
root : WARNING This is warring message
# cat lxy.log
#log文件
Thu, 12 Mar 2015 10:52:29 log [line:20] DEBUG This is debug message
Thu, 12 Mar 2015 10:52:29 log [line:21] INFO This is info message
Thu, 12 Mar 2015 10:52:29 log [line:22] WARNING This is warring message

四、logging日志回滚

Rotating英文意思是“旋转”。

# cat log2
import logging
from logging.handler import RotatingFieHandler

#定义一个RotatingFileHandle
Rthandler=RotatingFileHandler('lxy.log',maxBytes=10*1024*1024,backupCount=5)
Rthandler.setLevel(logging.INFO)
formatter=logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
Rthandler.setFormatter(formatter)
logging.getLogger('').addHandler(Rthandler)

从三和四可以看出:logging有一个日志处理的主对象,其它处理方式都是通过addHandler添加进去的。

logging的几种handler方式:

logging.StreamHandler:日志输出到流,可以是sys.stderr,sys.stdout或者文件
logging.FileHandler:日志输出到文件
日志回滚方式,实际使用时用RotatingFileHandler和TimedRotatingFileHandler
logging.handlers.BaseRotatingHandler
logging.handlers.RotatingFileHandler
logging.handlers.TimedRotatingFileHandler
logging.handlers.SocketHandler:远程输出日志到TCP/IP sockets
logging.handlers.DatagramHandler:远程输出日志到UDP sockets
logging.handlers.SMTPHandler:远程输出日志到邮件系统
logging.handlers.SysLogHandler:日志输出到syslog
logging.handlers.NTEventLogHandler:远程输出日志到Windows NT/2000/XP的事件日志
logging.handlers.MemoryHandler:日志输出到内存中特定buffer
logging.handlers.HTTPHandler:通过"GET"或“POST”远程输出到HTTP服务

由于StreamHandler和FileHandler是最常用的日志处理方式,所以直接包含在logging模块中,而其他方式则包含在logging.handlrs模块中。

Python 中文官方文档

http://python.usyiyi.cn/

Python官方教程中文版v2.7.8

http://python.usyiyi.cn/python_278/tutorial/index.html

python log的更多相关文章

  1. python log的处理方式

    python log的处理方式 配置文件 #! /usr/bin/env python # -*- coding: utf-8 -*- # __author__ = "Q1mi" ...

  2. Python log 模块介绍

    刚用Python log模块写了一个例子,记录一下. import logging import logging.handlers import os from datetime import dat ...

  3. python log 层次结构

    文件结构 - run.py - b -- __init__.py run.py import logging import b log = logging.getLogger("" ...

  4. python log封装

    # _*_ coding:utf-8 _*_ import logging import os import sys import time log_path = os.path.dirname(sy ...

  5. Python log() 函数

    描述 log() 方法返回x的自然对数,x > 0. 语法 以下是 log() 方法的语法: import math math.log( x ) 注意:log()是不能直接访问的,需要导入 ma ...

  6. python - log日志

    # -*- coding:utf-8 -*- ''' @project: jiaxy @author: Jimmy @file: study_logging.py @ide: PyCharm Comm ...

  7. python log 设置

    # -*- coding: utf-8 -*- import loggingfrom logging.handlers import TimedRotatingFileHandler  # 按时间处理 ...

  8. python log装饰器

    def log(func): #将原函数对象的指定属性复制给包装函数对象, 默认有 module.name.doc,或者通过参数选择 @functools.wraps(func) def wrappe ...

  9. Python Log Viewer

    https://pythonhosted.org/logview/

随机推荐

  1. 为Apple Push开发的PHP PEAR 包:Services_Apple_PushNotification

    Apple Push Notification Service:通过苹果服务器向app用户推送消息,无需启动app. 苹果官方文档:http://developer.apple.com/library ...

  2. scrollify.js 鼠标滚动

    在线实例 实例演示 使用方法 <! doctype html> <html> <head> <script> $(function() { $.scro ...

  3. SharePoint 2010商业智能组件

    Microsoft Office SharePoint Server (MOSS) 2007中,就已经提供了很多支持商业智能的能力.其中主要的组件包含Excel Services, Reporting ...

  4. 携带cookie进行数据请求

    前端进行数据请求有:普通的ajax(json)请求,jsop跨域请求,cors跨域请求,fetch请求...PC端这些请求方式中,普通的ajax(json)请求和jsop跨域请求是默认携带cookie ...

  5. 自动适应iframe右边的高度

    在开发项目过程中,用iframe嵌套,会发现一个问题,用iframe嵌套的html结构右边不会自动适应高度. 这时候找到了一个解决方法: <iframe name="my_iframe ...

  6. [js开源组件开发]模拟下拉选项框select

    模拟下拉选项框select 在css3流行的情况下,下拉框还是无法满足PD的需求,所以有了autosearch,有了模拟下拉框.效果如下图: select DEMO请案例点击这里查看.http://w ...

  7. C#添加dll引用后,添加命名空间出错的解决方案

    原因:类库dll的目标框架与项目的目标框架不一致造成的,右键单击项目project--〉属性 ---〉Application选项卡下有“目标框架”Target Framewiork,  遇到的是类库的 ...

  8. silverlight如何通过单独部署的WCF站点访问sharepoint2013的图片库

    最近有项目silverlight通过单独部署的WCF站点访问sharepoint2013的图片库,需要做个笑脸墙效果如下: 结果开发完毕后无法在SP站点显示出来.使用VS自带的WCF工具进行测试.如下 ...

  9. Ruby学习心得之 Linux下搭建Ruby环境

    作者:枫雪庭 出处:http://www.cnblogs.com/FengXueTing-px/ 欢迎转载 Ruby学习心得之 Linux下搭建Ruby环境1.前言2.Linux下安装Ruby环境 一 ...

  10. JSOM 中对各种字段操作

     function createListItem() {     var clientContext = new SP.ClientContext(_spPageContextInfo.siteAbs ...