python日志模块---logging

本文涉及的产品
日志服务 SLS,月写入数据量 50GB 1个月
简介: 1.将日志打印到屏幕 1 import logging 2 3 logging.debug('This is debug message---by liu-ke') 4 logging.info('This is info message---by liu-ke') 5 logging.

1.将日志打印到屏幕

1 import logging
2 
3 logging.debug('This is debug message---by liu-ke')
4 logging.info('This is info message---by liu-ke')
5 logging.warning('This is warning message---by liu-ke')

默认情况下,logging将日志打印到屏幕,日志级别为WARNING;
日志级别大小关系为:CRITICAL > ERROR > WARNING > INFO > DEBUG > NOTSET,日志级别可以自己定义。

 

2.通过logging.basicConfig函数 配置 日志的输出格式及方式

 1 import logging
 2 
 3 logging.basicConfig(level=logging.DEBUG,
 4                 format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
 5                 datefmt='%a, %d %b %Y %H:%M:%S',
 6                 filename='mypy.log',
 7                 filemode='w')
 8     
 9 logging.debug('This is debug message by liu-ke')
10 logging.info('This is info message by liu-ke')
11 logging.warning('This is warning message by liu-ke')
 1 logging.basicConfig函数各参数:
 2 filename: 指定日志文件名
 3 filemode: 和file函数意义相同,指定日志文件的打开模式,'w''a'
 4 format: 指定输出的格式和内容,format可以输出很多有用信息,如上例所示:
 5  %(levelno)s: 打印日志级别的数值
 6  %(levelname)s: 打印日志级别名称
 7  %(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0]
 8  %(filename)s: 打印当前执行程序名
 9  %(funcName)s: 打印日志的当前函数
10  %(lineno)d: 打印日志的当前行号
11  %(asctime)s: 打印日志的时间
12  %(thread)d: 打印线程ID
13  %(threadName)s: 打印线程名称
14  %(process)d: 打印进程ID
15  %(message)s: 打印日志信息
16 datefmt: 指定时间格式,同time.strftime()
17 level: 设置日志级别,默认为logging.WARNING
18 stream: 指定将日志的输出流,可以指定输出到sys.stderr,sys.stdout或者文件,默认输出到sys.stderr,当stream和filename同时指定时,stream被忽略

 

3.将日志同时输出到文件和屏幕

 1 import logging
 2 
 3 logging.basicConfig(level=logging.DEBUG,
 4                 format='%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s',
 5                 datefmt='%a, %d %b %Y %H:%M:%S',
 6                 filename='mypy.log',
 7                 filemode='w')
 8 
 9 #################################################################################################
10 #定义一个StreamHandler,将INFO级别或更高的日志信息打印到标准错误,并将其添加到当前的日志处理对象#
11 console = logging.StreamHandler()
12 console.setLevel(logging.INFO)
13 formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
14 console.setFormatter(formatter)
15 logging.getLogger('').addHandler(console)
16 #################################################################################################
17 
18 logging.debug('This is debug message')
19 logging.info('This is info message')
20 logging.warning('This is warning message')

 

4.logging之日志回滚

 1 import logging
 2 from logging.handlers import RotatingFileHandler
 3 
 4 #################################################################################################
 5 #定义一个RotatingFileHandler,最多备份5个日志文件,每个日志文件最大10M(自定义)
 6 Rthandler = RotatingFileHandler('myapp.log', maxBytes=10*1024*1024,backupCount=5)
 7 Rthandler.setLevel(logging.INFO)
 8 formatter = logging.Formatter('%(name)-12s: %(levelname)-8s %(message)s')
 9 Rthandler.setFormatter(formatter)
10 logging.getLogger('').addHandler(Rthandler)
11 ###########################################################################################

从上例和本例可以看出,logging有一个日志处理的主对象,其它处理方式都是通过addHandler添加进去的。
logging的几种handle方式如下:

 1 logging.StreamHandler: 日志输出到流,可以是sys.stderr、sys.stdout或者文件
 2 logging.FileHandler: 日志输出到文件
 3 日志回滚方式,实际使用时用RotatingFileHandler和TimedRotatingFileHandler
 4 logging.handlers.BaseRotatingHandler
 5 logging.handlers.RotatingFileHandler
 6 logging.handlers.TimedRotatingFileHandler
 7 logging.handlers.SocketHandler: 远程输出日志到TCP/IP sockets
 8 logging.handlers.DatagramHandler:  远程输出日志到UDP sockets
 9 logging.handlers.SMTPHandler:  远程输出日志到邮件地址
10 logging.handlers.SysLogHandler: 日志输出到syslog
11 logging.handlers.NTEventLogHandler: 远程输出日志到Windows NT/2000/XP的事件日志
12 logging.handlers.MemoryHandler: 日志输出到内存中的制定buffer
13 logging.handlers.HTTPHandler: 通过"GET""POST"远程输出到HTTP服务器

由于StreamHandler和FileHandler是常用的日志处理方式,所以直接包含在logging模块中,而其他方式则包含在logging.handlers模块中,
上述其它处理方式的使用请自行参见python2.7手册!

 

5.通过logging.config模块配置日志

 1 #logger.conf
 2 ###############################################
 3 [loggers]
 4 keys=root,example01,example02
 5 [logger_root]
 6 level=DEBUG
 7 handlers=hand01,hand02
 8 [logger_example01]
 9 handlers=hand01,hand02
10 qualname=example01
11 propagate=0
12 [logger_example02]
13 handlers=hand01,hand03
14 qualname=example02
15 propagate=0
16 ###############################################
17 [handlers]
18 keys=hand01,hand02,hand03
19 [handler_hand01]
20 class=StreamHandler
21 level=INFO
22 formatter=form02
23 args=(sys.stderr,)
24 [handler_hand02]
25 class=FileHandler
26 level=DEBUG
27 formatter=form01
28 args=('myapp.log', 'a')
29 [handler_hand03]
30 class=handlers.RotatingFileHandler
31 level=INFO
32 formatter=form02
33 args=('myapp.log', 'a', 10*1024*1024, 5)
34 ###############################################
35 [formatters]
36 keys=form01,form02
37 [formatter_form01]
38 format=%(asctime)s %(filename)s[line:%(lineno)d] %(levelname)s %(message)s
39 datefmt=%a, %d %b %Y %H:%M:%S
40 [formatter_form02]
41 format=%(name)-12s: %(levelname)-8s %(message)s
42 datefmt=

上例3:

1 import logging
2 import logging.config
3 
4 logging.config.fileConfig("logger.conf")
5 logger = logging.getLogger("example01")
6 
7 logger.debug('This is debug message')
8 logger.info('This is info message')
9 logger.warning('This is warning message')

上例4:

1 import logging
2 import logging.config
3 
4 logging.config.fileConfig("logger.conf")
5 logger = logging.getLogger("example02")
6 
7 logger.debug('This is debug message')
8 logger.info('This is info message')
9 logger.warning('This is warning message')

 

 


img_42a4adae4716d0e15c3eeaabfd040044.png

注:转载需注明出处及作者。

流柯      

相关实践学习
日志服务之使用Nginx模式采集日志
本文介绍如何通过日志服务控制台创建Nginx模式的Logtail配置快速采集Nginx日志并进行多维度分析。
目录
相关文章
|
3月前
|
开发者 Python
如何在Python中管理模块和包的依赖关系?
在实际开发中,通常会结合多种方法来管理模块和包的依赖关系,以确保项目的顺利进行和可维护性。同时,要及时更新和解决依赖冲突等问题,以保证代码的稳定性和可靠性
158 62
|
2月前
|
Python
Python Internet 模块
Python Internet 模块。
133 74
|
3月前
|
算法 数据安全/隐私保护 开发者
马特赛特旋转算法:Python的随机模块背后的力量
马特赛特旋转算法是Python `random`模块的核心,由松本真和西村拓士于1997年提出。它基于线性反馈移位寄存器,具有超长周期和高维均匀性,适用于模拟、密码学等领域。Python中通过设置种子值初始化状态数组,经状态更新和输出提取生成随机数,代码简单高效。
141 63
|
3月前
|
数据可视化 Python
如何在Python中解决模块和包的依赖冲突?
解决模块和包的依赖冲突需要综合运用多种方法,并且需要团队成员的共同努力和协作。通过合理的管理和解决冲突,可以提高项目的稳定性和可扩展性
|
3月前
|
Python
Python的模块和包
总之,模块和包是 Python 编程中非常重要的概念,掌握它们可以帮助我们更好地组织和管理代码,提高开发效率和代码质量
133 61
|
3月前
|
测试技术 Python
手动解决Python模块和包依赖冲突的具体步骤是什么?
需要注意的是,手动解决依赖冲突可能需要一定的时间和经验,并且需要谨慎操作,避免引入新的问题。在实际操作中,还可以结合使用其他方法,如虚拟环境等,来更好地管理和解决依赖冲突😉。
|
3月前
|
持续交付 Python
如何在Python中自动解决模块和包的依赖冲突?
完全自动解决所有依赖冲突可能并不总是可行,特别是在复杂的项目中。有时候仍然需要人工干预和判断。自动解决的方法主要是提供辅助和便捷,但不能完全替代人工的分析和决策😉。
|
1月前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
32 3
|
3月前
|
JSON Linux 数据格式
Python模块:从入门到精通,只需一篇文章!
Python中的模块是将相关代码组织在一起的单元,便于重用和维护。模块可以是Python文件或C/C++扩展,Python标准库中包含大量模块,如os、sys、time等,用于执行各种任务。定义模块只需创建.py文件并编写代码,导入模块使用import语句。此外,Python还支持自定义模块和包,以及虚拟环境来管理项目依赖。
Python模块:从入门到精通,只需一篇文章!
|
3月前
|
监控 开发者 Python
Python 默认 `logging` 打印级别详解
本文详细介绍了 Python `logging` 模块的默认打印级别及其配置方法。`logging` 模块支持 `DEBUG`、`INFO`、`WARNING`、`ERROR` 和 `CRITICAL` 五个日志级别,默认级别为 `WARNING`。文章通过示例代码展示了如何设置和使用不同日志级别,并介绍了进一步的配置选项,如日志格式和文件输出。
89 8

推荐镜像

更多