https://www.cnblogs.com/yyds/p/6901864.html

logging提供给了两种记录日志的方式:

第一种方式是使用logging提供的模块级别的函数

import logging

logging.basicConfig(filename='my.log',level=logging.DEBUG,format='%(asctime)s - %(levelname)s - %(message)s ',datefmt='%m/%d/%Y %H:%M:%S %p')

logging.debug("this is a debug log")

logging.info("this is a info log.")

logging.error("this is %d warning  %s log",10,'tom')

basicConfig()是一个日志系统的简单配置工具,只有在第一个调用该函数时会起作用

第二种方式是使用logging日志系统的四大组件

日志系统的四大组件:

Logger            日志器               日志记录的接口

Handler          处理器               设置日记的输出的位置,比如文件,控制台,网路等

Filter             过滤器                个性化日志记录结果的 过滤  ,关于filter有方法                addFilter()    ,      removeFilter()

Formatter      格式器                设置日志记录的格式

Logger就像一个带名字的容器,logger.addHandler(handl1),这样就启用了处理器1   handl1的日志处理器,removeHandler(handl1)可以移除一个处理器

Handler可通过 handl1.setLevel(logging.DEBUG)    , handl1.setFormatter(fomat1),handl1.addFilter(filter1) 设置日志记录的等级和格式,过滤规则

获取一个logger对象,可以通过logging.getLogger(name)获取对应name的标识,默认为‘root',若以相同的name多次调用getLogger()方法,将会返回同一个logger对象

logger对象创建后,可以通过logger.debug(),logger.info(),logger.warning(),logger.error(),logger.critical(),logger.expection()来记录对应等级的日志,

logger.expection()与logger.error()等级一致,只是expection()会记录错误栈

创建handler对象:

logging.StreamHandler()                                                 将日志输出到控制台

logging.FileHandler(filername,encoding='utf-8')            将日志输出到指定磁盘文件,默认文件大小无限增长

logging.handlers.RotatingFileHandler                              输出到文件,支持按日志大小切割

logging.handlers.TimedRotatingFileHandler                    输出到文件,支持按时间切割

logging.handlers.HTTPHandler                                        输出到http服务器,以get或post方式发送

logging.handlers.SMTPHandler                                        输出到指定的email地址

logging.NullHandler                                                          一个空的handler

日志流程

logger作为一个容器也有setLevel() , addFilter()方法,日志先 由 logger 进,总流路径,满足了 logger的level和filter等级才会继续流向 各个分流 Handler

在某分流上,满足这个handler的level和filter的日志 才会输出到handler对应的位置  .; 满足了logger的level和filter的要求的日志同时还会根据propagate的值来判断是否会将消息传给父级logger

import logging

import logging.handlers

import datetime

logger = logging.getLogger('mylogger')

logger.setLevel(logging.DEBUG)

rf_handler = logging.handlers.TimedRotatingFileHandler('all.log', when='midnight', interval=1, backupCount=7, atTime=datetime.time(0, 0, 0, 0))

rf_handler.setFormatter(logging.Formatter("%(asctime)s - %(levelname)s - %(message)s"))

f_handler = logging.FileHandler('error.log')

f_handler.setLevel(logging.ERROR)

f_handler.setFormatter(logging.Formatter("%(asctime)s - %(levelname)s - %(filename)s[:%(lineno)d] - %(message)s"))

logger.addHandler(rf_handler)

logger.addHandler(f_handler)

logger.debug('debug message')

logger.info('info message')

logger.warning('warning message')

logger.error('error message')

logger.critical('critical message')

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

  1. Python模块学习 ---- logging 日志记录

    许多应用程序中都会有日志模块,用于记录系统在运行过程中的一些关键信息,以便于对系统的运行状况进行跟踪.在.NET平台中,有非常著名的第三方开源日志组件log4net,c++中,有人们熟悉的log4cp ...

  2. Python模块学习:logging 日志记录

    原文出处: DarkBull    许多应用程序中都会有日志模块,用于记录系统在运行过程中的一些关键信息,以便于对系统的运行状况进行跟踪.在.NET平台中,有非常著名的第三方开源日志组件log4net ...

  3. python基础语法13 内置模块 subprocess,re模块,logging日志记录模块,防止导入模块时自动执行测试功能,包的理论

    subprocess模块: - 可以通过python代码给操作系统终端发送命令, 并且可以返回结果. sub: 子    process: 进程 import subprocess while Tru ...

  4. python3 logging 日志记录模块

    #coding:utf-8 import logginglogging.basicConfig(filename='log1.log', format='%(asctime)s -%(name)s-% ...

  5. Python开发之日志记录模块:logging

    1 引言 最近在开发一个应用软件,为方便调试和后期维护,在代码中添加了日志,用的是Python内置的logging模块,看了许多博主的博文,颇有所得.不得不说,有许多博主大牛总结得确实很好.似乎我再写 ...

  6. SLF4J - 一个允许你统一日志记录API的抽象层

    一.什么是SLF4J 我们在做Java开发时,如果需要记录日志,有很多日志API可供选择,如: java.util.logging Apache log4j logback SLF4J又是个什么东东呢 ...

  7. logging日志管理--将日志打印在屏幕上

    # -*- coding: cp936 -*- # test.py #http://blog.chinaunix.net/uid-27571599-id-3492860.html #logging日志 ...

  8. python中利用logging包进行日志记录时的logging.level设置选择

    之前在用python自带的logging包进行日志输出的时候发现有些logging语句没有输出,感到比较奇怪就去查了一下logging文档.然后发现其在设置和引用时的logging level会影响最 ...

  9. 基于java.util.logging实现轻量级日志记录库(增加根据当前类class初始化,修复线程池模型(javaEE)下的堆栈轨迹顺序与当前调用方法不一致问题)

    前言: 本章介绍自己写的基于java.util.logging的轻量级日志记录库(baseLog). 该版本的日志记录库犹如其名,baseLog,是个实现日志记录基本功能的小库,适合小型项目使用,方便 ...

  10. Asp.Net Core 2.0 项目实战(9) 日志记录,基于Nlog或Microsoft.Extensions.Logging的实现及调用实例

    本文目录 1. Net下日志记录 2. NLog的使用     2.1 添加nuget引用NLog.Web.AspNetCore     2.2 配置文件设置     2.3 依赖配置及调用     ...

随机推荐

  1. 打印图形|2014年蓝桥杯B组题解析第五题-fishers

    打印图形 小明在X星球的城堡中发现了如下图形和文字: rank=3 rank=5 rank = 6 小明开动脑筋,编写了如下的程序,实现该图形的打印. 答案:f(a, rank-1, row, col ...

  2. 【第十五章】 springboot + pojo默认值设置

    我们有时需要给POJO设置默认值 pojo设置(推荐) 1.User package com.xxx.firstboot.domain; import lombok.Getter; import lo ...

  3. 第十一章 非对称加密算法--DH

    注意:本节内容主要参考自<Java加密与解密的艺术(第2版)>第8章“高等加密算法--非对称加密算法” 11.1.非对称加密算法 特点: 发送方和接收方均有一个密钥对(公钥+私钥),其中公 ...

  4. Python matplot的使用(一)

    其实,使用它的直接原因是因为matlab太大了,不方便.另外,就是它是免费的. 在安装这个库的时候,会需要安装一些它所依赖的库,比如six等.从sourceforge上下载,只需按照提示安装完成就行了 ...

  5. Ubuntu 14.04 编写service 服务

    有时我们需要将特定操作封装成服务,通过服务启动停止,例如nginx的启动停止,service nginx start 或者service nginx stop 下面我们将编写一个demo cd /et ...

  6. chrome表单自动填充去掉input黄色背景

    input文本框是纯色背景的 1. input:-webkit-autofill { -webkit-box-shadow: 0 0 0px 1000px white inset!important; ...

  7. Linux忘记root登录密码解决方法

    有时候由于长时间米有登录linux系统,等需要用的时候突然忘记root密码,怎么办?下面简单介绍解决方法. redhat 和 centos 6.5 可以,7.0以上未测 在系统重启后,不停地按”e”键 ...

  8. Log4J日志配置详解[转]

    一.Log4j简介 Log4j有三个主要的组件:Loggers(记录器),Appenders (输出源)和Layouts(布局).这里可简单理解为日志类别,日志要输出的地方和日志以何种形式输出.综合使 ...

  9. Python -- xlrd,xlwt,xlutils 读写同一个Excel

    最近开始学习python,想做做简单的自动化测试,需要读写excel,然后就找到了xlrd来读取Excel文件,使用xlwt来生成Excel文件(可以控制Excel中单元格的格式),需要注意的是,用x ...

  10. m_Orchestrate learning system---三十三、公共变量多弄成全局变量

    m_Orchestrate learning system---三十三.公共变量多弄成全局变量 一.总结 一句话总结:比如班级id,小组id,这样省事,而且减少数据库的访问,加快访问速度,而且节约代码 ...