『无为则无心』Python日志 — 65、日志模块logging的使用
1、logger类用法
logger
类:logger
用于提供日志接口,常用于配置和发送日志消息。
我们一般使用logging.getLogger(name)
方法来获得一个logger
对象。
其中,可选参数name
指定日志器名称,默认为“root”。
常用方法包括:
logger.setLevel()
:设置日志器处理日志信息的最低级别。logger.addHandler()
:为该logger
对象添加一个handler
对象。logger.removeHandler()
:为该logger
对象添加移除一个handler
对象。logger.addFilter()
:为该logger
对象添加一个filter
对象。logger.removeFilter()
:为该logger
对象移除一个filter
对象。- 创建一个对应等级的日志记录:
logger.debug()
logger.info()
logger.warning()
logger.error()
logger.critical()
logger.log()
:获取一个日志level
参数,来创建一个日志记录。
示例:
"""
logging模块是Python的内置模块,不需要安装。
"""
# 导入logging模块
import logging
# 创建一个日志器,就是一个logger对象
logger = logging.getLogger('logger')
# 输出日志信息
logger.debug('输出debug级别的日志')
logger.info('输出info级别的日志')
logger.warning('输出warning级别的日志')
logger.error('输出error级别的日志')
logger.critical('输出critical级别的日志')
"""
# 右键执行代码
# 结果如下:
输出warning级别的日志
输出error级别的日志
输出critical级别的日志
"""
总结:
默认情况下Python的logging
模块将日志打印到了标准输出中(控制台),且只显示了大于等于WARNING级别的日志,这说明默认的日志级别设置为WARNING。
2、handler类用法
handler
类:handler
对象用于将指定的日志信息发送到指定的位置。
一个logger
对象可以添加多个handler
,每个handler
又可以定义不同日志级别,以实现日志分级过滤显示。
也就是说通过handler
我们可以将日志同时输出到多个位置。
常用的方法包括:
handler.setLevel()
:设置handler
处理的日志信息最低级别。handler.setFormatter()
:为handler
设置一个格式器对象。handler.addFilter()
:为handler
添加一个过滤器对象。handler.removeFilter()
:为handler
删除一个过滤器对象。logging.StreamHandler()
:将日志信息发送到Stream
。logging.FileHandler()
:将日志消息发送到磁盘文件。
示例:把上面的示例,实现DEBUG级别日志的输出。
"""
logging模块是Python的内置模块,不需要安装。
"""
# 导入logging模块
import logging
# 创建一个日志器,就是一个logger对象
logger = logging.getLogger('logger')
# 1.设置logger日志级别
logger.setLevel(logging.DEBUG)
# 2.创建一个输出的处理器,让它输入到控制台
sh = logging.StreamHandler()
# 3.把输出处理器添加到日志器中
logger.addHandler(sh)
# 输出日志信息
logger.debug('输出debug级别的日志')
logger.info('输出info级别的日志')
logger.warning('输出warning级别的日志')
logger.error('输出error级别的日志')
logger.critical('输出critical级别的日志')
"""
# 右键执行代码
# 结果如下:
输出debug级别的日志
输出info级别的日志
输出warning级别的日志
输出error级别的日志
输出critical级别的日志
"""
说明:
当我们设置好logger
日志级别后,执行代码,发现还是和上面一样,只输出了warning
级别日志。
这个时候我们是改变了logger
默认设置,就需要创建一个日志处理器Handler
,来处理输出这个自定义logger
对象的日志输出。
3、formatter类用法
formatter
类:formatter
对象用来输出格式化字符串,也叫做格式器。
构造方法如下:
logging.Formatter.__init__(fmt=None, datefmt=None)
其中:
fmt
:指定信息(日志)的格式化字符串,如不设定则使用信息的原始字符串。
datefmt
:指定日期的格式化字符串,如不设定则使用默认格式"%Y-%m-%d %H:%M:%S"
logging
模块中定义好的可以用于format
格式字符串说明:
字段/属性名称 | 使用格式 | 描述 |
---|---|---|
asctime |
%(asctime)s |
将日志的时间构造成可读的形式,默认情况下是‘2016-02-08 12:00:00,123’ 精确到毫秒。 |
name |
%(name)s |
所使用的日志器名称,默认是root ,因为默认使用的是 rootLogger 。 |
filename |
%(filename)s |
调用日志输出函数的模块的文件名; pathname 的文件名部分,包含文件后缀。 |
funcName |
%(funcName)s |
由哪个function 发出的log , 调用日志输出函数的函数名。 |
levelname |
%(levelname)s |
日志的最终等级(被filter 修改后的)。 |
message |
%(message)s |
日志信息, 日志记录的文本内容。 |
lineno |
%(lineno)d |
当前日志的行号, 调用日志输出函数的语句所在的代码行。 |
levelno |
%(levelno)s |
该日志记录的数字形式的日志级别(10, 20, 30, 40, 50)。 |
pathname |
%(pathname)s |
完整路径 ,调用日志输出函数的模块的完整路径名,可能没有。 |
process |
%(process)s |
当前进程, 进程ID。可能没有。 |
processName |
%(processName)s |
进程名称,Python 3.1新增。 |
thread |
%(thread)s |
当前线程, 线程ID。可能没有。 |
threadName |
%(thread)s |
线程名称。 |
module |
%(module)s |
调用日志输出函数的模块名,filename 的名称部分,不包含后缀即不包含文件后缀的文件名。 |
created |
%(created)f |
当前时间,用UNIX标准的表示时间的浮点数表示; 日志事件发生的时间--时间戳,就是当时调用time.time() 函数返回的值。 |
relativeCreated |
%(relativeCreated)d |
输出日志信息时的,自Logger 创建以 来的毫秒数; 日志事件发生的时间相对于logging 模块加载时间的相对毫秒数。 |
msecs |
%(msecs)d |
日志事件发生事件的毫秒部分。logging.basicConfig() 中用了参数datefmt ,将会去掉asctime 中产生的毫秒部分,可以用这个加上。 |
示例:
"""
logging模块是Python的内置模块,不需要安装。
步骤:
1,定义格式器
2,把格式器输入处理器中
"""
# 导入logging模块
import logging
# 创建一个日志器,就是一个logger对象
logger = logging.getLogger('logger')
# 设置logger输入级别
logger.setLevel(logging.DEBUG)
# 1.创建日志格式器
formator = logging.Formatter(fmt="%(asctime)s [ %(filename)s ] %(lineno)d行 | [ %(levelname)s ] | [%(message)s]",
datefmt="%Y/%m/%d/%X")
# 创建一个输出的处理器,让它输入到控制台
sh = logging.StreamHandler()
# 把输出处理器添加到日志器中
logger.addHandler(sh)
# 2.给处理器添加格式器
sh.setFormatter(formator)
# 输出日志信息
logger.debug('输出debug级别的日志')
logger.info('输出info级别的日志')
logger.warning('输出warning级别的日志')
logger.error('输出error级别的日志')
logger.critical('输出critical级别的日志')
"""
# 右键执行代码
# 结果如下:
2021/01/15/03:15:44 [ demo_log2.py ] 27行 | [ DEBUG ] | [输出debug级别的日志]
2021/01/15/03:15:44 [ demo_log2.py ] 28行 | [ INFO ] | [输出info级别的日志]
2021/01/15/03:15:44 [ demo_log2.py ] 29行 | [ WARNING ] | [输出warning级别的日志]
2021/01/15/03:15:44 [ demo_log2.py ] 30行 | [ ERROR ] | [输出error级别的日志]
2021/01/15/03:15:44 [ demo_log2.py ] 31行 | [ CRITICAL ] | [输出critical级别的日志]
"""
4、filter类用法
filter类
:filter
是一个过滤器,可以实现比logger
和handle
更细致灵活的过滤功能。
设置只输出符合过滤条件的日志记录,提供给Logger
类和Handler
类使用。
Logger
类默认过滤具有相同前缀的所有日志记录。
Logger
只有在处理日志记录时即时检查Filter
,所以继承Logger
不会检查Filter
。
Handler
首先注册Filter
,然后在处理后续日志记录时检查。
首先定义logging.Filter
的扩展类,并在其中实现def filter(self, record)
方法。然后创建定制Filter
类的实例,并通过addFilter()
方法附加到Logger
和Handler
。
『无为则无心』Python日志 — 65、日志模块logging的使用的更多相关文章
- 『无为则无心』Python日志 — 64、Python日志模块logging介绍
目录 1.日志的作用 2.为什么需要写日志 3.Python中的日志处理 (1)logging模块介绍 (2)logging模块的四大组件 (3)logging日志级别 1.日志的作用 从事与软件相关 ...
- 『无为则无心』Python日志 — 66、将日志信息保存到文件中
目录 1.把日志信息保存到文件中 2.拓展 (1)观察代码 (2)提出问题 (3)问题说明 1.把日志信息保存到文件中 代码如下所示: """ logging模块是Pyt ...
- 『无为则无心』Python日志 — 67、logging日志模块处理流程
目录 1.概括理解 2.详细说明 3.应用示例 1.概括理解 了解了四大组件的基本定义之后,我们通过图示的方式来理解下信息的传递过程: 也就是获取的日志信息,进入到Logger日志器中,传递给处理器确 ...
- 『无为则无心』Python基础 — 44、对文件和文件夹的操作
目录 1.os模块介绍 2.查看os模块相关文档 3.os模块常用方法 (1)文件重命名 (2)删除文件 (3)创建文件夹 (4)删除文件夹 (5)获取当前目录 (6)改变默认目录 (7)获取目录列表 ...
- 『无为则无心』Python日志 — 69、补充:logging.basicConfig()函数说明
目录 1.basicConfig()函数说明 2.应用 1.basicConfig()函数说明 此函数,通过创建一个带有默认Formatter(格式器)的StreamHandler(处理器),并将其添 ...
- 『无为则无心』Python基础 — 9、Python字符串的编码与转义
目录 1.查看变量类型 2.转义字符 (1)转义字符说明 (2)示例 (3)常用转义字符对照表 3.字符编码 (1)字符编码介绍 (2)Python中的字符编码 (3)编码格式应用于不同场景 提示:上 ...
- 『无为则无心』Python基础 — 2、编译型语言和解释型语言的区别
目录 1.什么是计算机语言 2.高级语言中的编译型语言和解释型语言 (1)编译型语言 (2)解释型语言 (3)编译型语言和解释型语言执行流程 3.知识扩展: 4.关于Python 1.什么是计算机语言 ...
- 『无为则无心』Python基础 — 3、搭建Python开发环境
目录 1.Python开发环境介绍 2.Python解释器的分类 3.下载Python解释器 4.安装Python解释器 5.Python解释器验证 1.Python开发环境介绍 所谓"工欲 ...
- 『无为则无心』Python基础 — 4、Python代码常用调试工具
目录 1.Python的交互模式 2.IDLE工具使用说明 3.Sublime3工具的安装与配置 (1)Sublime3的安装 (2)Sublime3的配置 4.使用Sublime编写并调试Pytho ...
随机推荐
- go生成随机数字验证码
一行代码搞定 code := fmt.Sprintf("%06v", rand.New(rand.NewSource(time.Now().UnixNano())).Int31n( ...
- gin中映射查询字符串或表单参数
package main import ( "fmt" "github.com/gin-gonic/gin" ) func main() { r := gin. ...
- 多选菜单shell脚本
有 很多方法 可以读取Bash脚本中的用户输入. 但是,允许用户键入输入会带来一些问题. 主要问题是输入验证,您必须在其中考虑所有可能的输入. 解决此问题的一种简单方法是为Bash脚本创建一个多选菜单 ...
- maven常用打包命令
常用maven命令 执行与构建过程(编译,测试,打包)相关的命令必须进入pom.xml所在位置执行 mvn clean:清理(打包好的程序放在生成的名为target的文件中,清理即删除文件中打包好的程 ...
- 学习JAVAWEB第十二天
## Servlet: 1. 概念 2. 步骤 3. 执行原理 4. 生命周期 5. Servlet3.0 注解配置 6. Servlet的体系结构 Servlet -- 接口 | GenericSe ...
- 3,linux-yum源配置-systemctl服务管理-文件权限
3,linux-yum源配置-systemctl服务管理-文件权限 小问答: 1.配置好阿里云yum源 生成yum缓存 下载nginx,并且启动nginx服务,使用浏览器访问10.0.0.10:80 ...
- 随机IP代理插件Scrapy-Proxies
安装: pip install scrapy_proxies github: https://github.com/aivarsk/scrapy-proxies scrapy爬虫配置文件setti ...
- linux 权限命令行 xshell 切换用户
一. 权限命令行 两种方式. 1.1 chown -R 指定的用户名, 权限的文件/文件夹 赋予这个用户的权限读写. /*1.0 权限命令行 1. chown -R 指定的用户名 权限的文件/文件夹 ...
- Ajax创建对象的方法
ajax涉及的技术包括Html.css.dom.xml.javascript等. 主流创建ajax对象的方法: IE6以下版本浏览器创建ajax对象方法是: 定义一个方法创建ajax对象:
- 如何按规定的格式向mysql中导入数据
1.首先我们拿到数据,数据必须按照一定的格式书写的.如用|区分字段,换行区分row 12107 | 心情1 | 今天的心情很不好啊. 12108 | 天气 | 今天天气还行. 12109 | 臭美 | ...