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

作者:轻舞肥羊 时间:2021-09-29 01:16:38 

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

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

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

1. 写日志的类

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

写日志的类


'''
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


[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,写日志文件
0
投稿

猜你喜欢

  • JS打开新窗口的2种方式

    2023-07-07 02:44:49
  • Django实现简单的分页功能

    2021-08-08 20:53:14
  • Python中如何使用if语句处理列表实例代码

    2023-11-01 03:12:46
  • python使用matplotlib绘制雷达图

    2022-10-10 16:37:41
  • pandas将list数据拆分成行或列的实现

    2023-12-23 01:58:41
  • Python 一键获取百度网盘提取码的方法

    2023-11-30 06:13:49
  • Python+Pygame编写一个Pong游戏

    2023-08-04 15:58:31
  • MySQL中对表连接查询的简单优化教程

    2024-01-25 19:15:49
  • TensorFlow人工智能学习张量及高阶操作示例详解

    2022-04-15 15:37:52
  • python版本的仿windows计划任务工具

    2021-06-09 03:55:07
  • 如何调用Oracle存储过程?

    2009-11-15 20:13:00
  • python根据完整路径获得盘名/路径名/文件名/文件扩展名的方法

    2023-07-18 12:15:22
  • isset和empty的区别

    2023-11-20 12:24:08
  • Python 开发工具通过 agent 代理使用的方法

    2022-10-19 05:15:31
  • pandas 两列时间相减换算为秒的方法

    2022-04-15 00:30:07
  • 首页访问感受提升三步曲

    2007-12-13 20:36:00
  • MySQL如何删除表中的数据

    2024-01-13 00:12:41
  • Nodejs封装类似express框架的路由实例详解

    2024-05-11 10:17:43
  • Python面向对象编程之类的概念

    2021-12-24 10:56:33
  • MySQL查询条件中in会用到索引吗

    2024-01-15 06:46:43
  • asp之家 网络编程 m.aspxhome.com