gpt4 book ai didi

python写日志文件操作类与应用示例

转载 作者:qq735679552 更新时间:2022-09-28 22:32:09 29 4
gpt4 key购买 nike

CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.

这篇CFSDN的博客文章python写日志文件操作类与应用示例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.

本文实例讲述了python写日志文件操作类与应用。分享给大家供大家参考,具体如下:

项目的开发过程中,日志文件是少不了的,通过写日志文件,可以知道程序运行的情况。特别当部署在生产环境中的时候,这个时候一般不能debug , 当然在有些情况时可以 remote debug (远程debug)。那种情况另当别论。还是用通常的写日志的方法,比如在 java 中,经常可以看到 log4j,sf4j,logback等三方组件来写日志.

在python中如何实现呢,其实python 本身也带了日志操作的库。可以直接使用。这里我把在项目中用到的整理了一下,分享在下面,这个实现的方法,主要有两点 。

1. 写日志的类 。

2.日志配置文件(handler,logger,以及日志保存的路径等) 。

写日志的类 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
'''
Created on 2012-2-17
@author: yihaomen.com
'''
import logging.config
import os
class INetLogger:
   log_instance = None
   @staticmethod
   def InitLogConf():
     currentDir = os.path.dirname(__file__)
     INetLogger.log_instance = logging.config.fileConfig(currentDir + os.path.sep + "logger.ini" )
   @staticmethod
   def GetLogger(name = ""):
     if INetLogger.log_instance = = None :
       INetLogger.InitLogConf()
     INetLogger.log_instance = logging.getLogger(name)
     return INetLogger.log_instance
if __name__ = = "__main__" :
   logger = INetLogger.GetLogger()
   logger.debug( "debug message" )
   logger.info( "info message" )
   logger.warn( "warn message" )
   logger.error( "error message" )
   logger.critical( "critical message" )
   logHello = INetLogger.GetLogger( "root" )
   logHello.info( "Hello world!" )

日志配置文件,与上面的类在同一文件夹下 logger.ini 。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
[loggers]
keys = root,mysql,socket
[handlers]
keys = consoleHandler,rotateFileHandler
[formatters]
keys = simpleFormatter
[formatter_simpleFormatter]
format = [ % (asctime)s][ % (levelname)s] [ % (filename)s: % (lineno)d] [thread: % (thread)d]: % (message)s
[logger_root]
qualname = root
level = DEBUG
handlers = consoleHandler,rotateFileHandler
[logger_mysql]
qualname = mysql
level = DEBUG
handlers = rotateFileHandler
[logger_socket]
qualname = socket
level = ERROR
handlers = rotateFileHandler
[handler_consoleHandler]
class = StreamHandler
level = DEBUG
formatter = simpleFormatter
args = (sys.stdout,)
[handler_rotateFileHandler]
class = handlers.RotatingFileHandler
level = DEBUG
formatter = simpleFormatter
args = ( 'c:/logs/InetServer.log' , 'a' , 2000000 , 9 )

如果你用了 handler_rotateFileHandler 的话,这样日志就会保存到 才c:/logs/InetServer.log 文件里面,而且当日志超过2000000 d的时候,重新另外生成一个文件,保存9天的记录,你可以配置成30,这样就保存了最近一个月的日志记录.

希望本文所述对大家Python程序设计有所帮助.

原文链接:http://www.yihaomen.com/article/python/262.htm 。

最后此篇关于python写日志文件操作类与应用示例的文章就讲到这里了,如果你想了解更多关于python写日志文件操作类与应用示例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。

29 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com