logging 专门用于记录日志的模块,相对于print来说,logging 提供了日志信息的分级、格式化、过滤等功能。在程序中定义丰富有条理的log信息,可以方便分析程序的运行状态,在发生问题是可有效定位和分析问题。

logging的几个部分:

1. Logger:进行日志记录时创建的对象,调用它的方法传入日志模板和信息 来生成日志记录logRecord

2. Handler:用来处理日志记录的类,指定输入日志位置和存储形式等

3. Formatter:指定日志的输出格式,返回字符串给 Handler 处理

4. Filter:通过级别或者关键字等过滤日志

5. Parent Handler: Handler 之间存在层级关系,使不同的 Handler 间可共享相同功能的代码

用法:

1:默认 Logger 和 basicConfig 格式输出

import logging
import time # 返回一个默认的root Logger,默认level=warning,打印内容为每个级别的信息
logger = logging.getLogger()
# 格式化输出log信息,返回的是日志字符串,传回给 Handler 来处理。
logging.basicConfig(
# 指定log级别:CRITICAL > ERROR > WARNING > INFO > DEBUG > NOTSET
# FATAL:致命错误;CRITICAL:内存磁盘空间耗尽等;ERROR:IO操作失败或连接有问题;WARNING:警告不是错误;INFO:处理请求或日常状态变化;DEBUG:调试信息中间状态等
level= logging.ERROR,
# 指定保存log信息的文件名称
filename="logging.txt",
# 设置文件的读写方式
# r 只读、w 创建覆盖写入、a 创建追加写入、
# rb 二进制格式打开只读、wb 二进制创建覆盖写入、ab 二进制创建追加写入、
# r+ 打开读写、w+ 创建覆盖读写、a+ 创建追加读写
# rb+ 二进制格式打开读写、wb+ 二进制创建覆盖读写;ab+ 二进制追加读写
filemode="w",
# 格式化输出
format=" 日志时间:%(asctime)s \n"
" 日志级别数值:%(levelno)s \n"
" 日志级别名称:%(levelname)s \n"
" 打印日志信息:%(message)s \n"
" 当前执行程序的路径:%(pathname)s \n"
" 当前执行程序名:%(filename)s \n"
" 当前模块名:%(name)s \n"
" 当前执行函数:%(funcName)s \n"
" 日志的当前行号:%(lineno)s \n"
" 线程ID:%(thread)d \n"
" 线程名称:%(threadName)s \n"
" 进程ID:%(process)d \n"
"----------------------------------",
# 设置 asctime 的输出格式
datefmt= time.strftime("%Y-%m-%d %X")
) logger.info("info message")
logger.debug("debug message")
logger.warning("warning message")
logger.error("error message")
logging.critical("critical error message") """
运行结果:打印log到logging.txt文件中 日志时间:2019-03-19 16:23:10
日志级别数值:40
日志级别名称:ERROR
打印日志信息:error message
当前执行程序的路径:/Users/soumoemoe/Documents/pyAutoTest/log.py
当前执行程序名:log.py
当前模块名:root
当前执行函数:<module>
日志的当前行号:40
线程ID:140735671509888
线程名称:MainThread
进程ID:42144
----------------------------------
日志时间:2019-03-19 16:23:10
日志级别数值:50
日志级别名称:CRITICAL
打印日志信息:critical error message
当前执行程序的路径:/Users/soumoemoe/Documents/pyAutoTest/log.py
当前执行程序名:log.py
当前模块名:root
当前执行函数:<module>
日志的当前行号:41
线程ID:140735671509888
线程名称:MainThread
进程ID:42144
----------------------------------
"""

2:Logger、Handler、Formatter、addHandler

import logging
import sys
# 声明 logger
logger = logging.getLogger(__name__)
# 指定log级别
logger.setLevel(logging.DEBUG) # FileHandler log日志格式化输出到文件中
fileHandler = logging.FileHandler("logging.txt")
formatter = logging.Formatter("%(asctime)s - %(name)s - %(levelname)s - %(message)s")
fileHandler.setFormatter(formatter)
logger.addHandler(fileHandler) # StreamHandler sys.stderr,sys.stdout 输出到控制台
streamHandler = logging.StreamHandler(sys.stderr)
streamHandler.setLevel(level=logging.DEBUG)
logger.addHandler(streamHandler) logger.info("This is a log info")
logger.debug("Debugging")
logger.warning("Warning exists")
logger.error("Error Message")
logger.critical("Critical message")

3:Parent Handler,logger配置服用,以下childlog.py复用了log.py文件中Logger的配置,注意两个文件中 getLogger的参数

#log.py

import logging
import sys
import childlog logger = logging.getLogger("log")
logger.setLevel(logging.DEBUG) streamHandler = logging.StreamHandler(sys.stderr)
streamHandler.setLevel(level=logging.DEBUG)
formatter = logging.Formatter("%(asctime)s - %(filename)s - %(levelname)s - %(message)s")
streamHandler.setFormatter(formatter)
logger.addHandler(streamHandler) logger.info("Log Info")
logger.debug("Log Debug")
logger.warning("Log Warning")
logger.error("Log Error")
logger.critical("Log Critical") childlog.run()
# childlog.py

import logging
logger = logging.getLogger("log.childlog")
def run():
logger.info("Child Info")
logger.debug("Child Debug")
logger.error("Child Error")

运行log.py 结果为:

2019-03-19 17:10:13,951 - log.py - INFO - Log Info
2019-03-19 17:10:13,951 - log.py - DEBUG - Log Debug
2019-03-19 17:10:13,951 - log.py - WARNING - Log Warning
2019-03-19 17:10:13,951 - log.py - ERROR - Log Error
2019-03-19 17:10:13,951 - log.py - CRITICAL - Log Critical
2019-03-19 17:10:13,951 - childlog.py - INFO - Child Info
2019-03-19 17:10:13,951 - childlog.py - DEBUG - Child Debug
2019-03-19 17:10:13,951 - childlog.py - ERROR - Child Error

4:异常捕获,打印Traceback信息:或者用exception打印

list = [1,2]
try:
for i in range(3):
print(list[i])
except Exception:
logger.error("访问列表出错") """
运行结果:
2019-03-19 17:16:42,608 - log.py - ERROR - 访问列表出错
1
2
""" #-----------------------------------------------------------------
# 设置 exc_info = True,会输出完整的Traceback信息
list = [1,2]
try:
for i in range(3):
print(list[i])
except Exception:
logger.error("访问列表出错", exc_info = True)
#logger.exception("访问列表出错") """
运行结果:
2019-03-19 17:18:37,204 - log.py - ERROR - 访问列表出错
Traceback (most recent call last):
File "/Users/soumoemoe/Documents/pyAutoTest/log.py", line 68, in <module>
print(list[i])
IndexError: list index out of range
1
2
"""

5:Filter 通过Logger名称过滤log

import logging
import sys logger = logging.getLogger("log") streamHandler = logging.StreamHandler(sys.stderr)
streamHandler.setLevel(level=logging.DEBUG)
formatter = logging.Formatter("%(asctime)s - %(filename)s - %(levelname)s - %(message)s")
streamHandler.setFormatter(formatter)
logger.addHandler(streamHandler) filter = logging.Filter(name = "log.a")
streamHandler.addFilter(filter) logging.getLogger("log.a").warning("log.a")
logging.getLogger("log.b").warning("log.b") #log.b没有输出 """
运行结果:
2019-03-19 17:33:39,979 - log.py - WARNING - log.a
"""

python logging模块的使用的更多相关文章

  1. python logging模块可能会令人困惑的地方

    python logging模块主要是python提供的通用日志系统,使用的方法其实挺简单的,这块就不多介绍.下面主要会讲到在使用python logging模块的时候,涉及到多个python文件的调 ...

  2. python logging模块使用

    近来再弄一个小项目,已经到收尾阶段了.希望加入写log机制来增加程序出错后的判断分析.尝试使用了python logging模块. #-*- coding:utf-8 -*- import loggi ...

  3. 读懂掌握 Python logging 模块源码 (附带一些 example)

    搜了一下自己的 Blog 一直缺乏一篇 Python logging 模块的深度使用的文章.其实这个模块非常常用,也有非常多的滥用.所以看看源码来详细记录一篇属于 logging 模块的文章. 整个 ...

  4. (转)python logging模块

    python logging模块 原文:http://www.cnblogs.com/dahu-daqing/p/7040764.html 1 logging模块简介 logging模块是Python ...

  5. Python logging 模块学习

    logging example Level When it's used Numeric value DEBUG Detailed information, typically of interest ...

  6. python logging—模块

    python logging模块 python logging提供了标准的日志接口,python logging日志分为5个等级: debug(), info(), warning(), error( ...

  7. Python logging模块无法正常输出日志

    废话少说,先上代码 File:logger.conf [formatters] keys=default [formatter_default] format=%(asctime)s - %(name ...

  8. 0x03 Python logging模块之Formatter格式

    目录 logging模块之Formatter格式 Formater对象 日志输出格式化字符串 LogRecoder对象 时间格式化字符串 logging模块之Formatter格式 在记录日志是,日志 ...

  9. 0x01 Python logging模块

    目录 Python logging 模块 前言 logging模块提供的特性 logging模块的设计过程 logger的继承 logger在逻辑上的继承结构 logging.basicConfig( ...

  10. Python Logging模块的简单使用

    前言 日志是非常重要的,最近有接触到这个,所以系统的看一下Python这个模块的用法.本文即为Logging模块的用法简介,主要参考文章为Python官方文档,链接见参考列表. 另外,Python的H ...

随机推荐

  1. Ubuntu使用tzselect修改时区

    1.命令行运行 sudo tzselect 2.选择洲区(这里选择亚洲Asia) waichung@desktop:~$ sudo tzselect [sudo] password for waich ...

  2. 5、Semantic-UI之基础按钮样式

    5.1 基础按钮样式   在Semantic-UI中定义了很多的按钮样式,可以通过class="ui button"来指定,也可以在class中指定颜色. 示例:定义基础按钮样式 ...

  3. WinAPI 字符及字符串函数(10): lstrcpy - 复制字符串

    unit Unit1; interface uses   Windows, Messages, SysUtils, Variants, Classes, Graphics, Controls, For ...

  4. Android-自定义IntentSession来传递数据

    在上一篇博客中介绍到,Android-Intent意图传递数据,能够传递基本数据类型系列,能够传递对象(需要序列化),等操作: 但是如果要传递 List<T>,这种类型的数据,就不能通过I ...

  5. duilib入门简明教程 -- XML基础类(7)

    现在大家应该对XML描述界面不那么陌生了,那么我们做进一步介绍. 前面的教程我们写了很多代码,为的是让大家了解下基本流程,其实duilib已经对常用的操作做了很好的包装,正式使用时无需像前面的教程那样 ...

  6. 数独高阶技巧入门之七——AIC & Nice Loop

    AIC(交替推理链,Alternate Inference Chain) 在简单异数链一文中我们介绍过XY-Chain技法,AIC可以看作是XY-Chain的扩展.有别于XY-Chain仅局限于双值格 ...

  7. Qt自动填写表单并点击按钮,包括调用js方法

    本篇博客参阅了很多其他大牛的文章,具体找不到了,还望包涵>_< 因为其他博客大都是只有主要代码,对于像我这种菜鸟,根本摸不着头脑,以此想总结一下,帮助新手尽快实现功能... 主要是调用了C ...

  8. Autofac的简单使用

    今天记录一下学习Autofac的过程. 之前对IoC与DI一直很迷糊,今天研究了前辈们的文章后,才对IoC和DI有了一个初步的了解.感谢前辈们的无私奉献! 文章地址: 依赖注入和控制反转的理解,写的太 ...

  9. table数据跑马灯效果

    1.使用marquee标签实现普通文本字符串跑马灯效果. <marquee behavior="scroll" scrollamount="3" styl ...

  10. 编写高质量JS代码上

    想写出高效的javascript类库却无从下手: 尝试阅读别人的类库,却理解得似懂给懂: 打算好好钻研js高级函数,但权威书上的内容太零散, 即使记住“用法”,但到要“用”的时候却没有想“法”. 也许 ...