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,写日志文件
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
Django MTV和MVC的区别详解
2023-06-08 10:15:19
![](https://img.aspxhome.com/file/2023/0/75140_0s.png)
Python 中 -m 的典型用法、原理解析与发展演变
2023-07-09 17:11:40
![](https://img.aspxhome.com/file/2023/0/87550_0s.jpg)
网页设计:巧用记事本编辑网页
2008-02-05 09:00:00
asp连接mysql数据库详细实现代码
2012-12-04 19:56:39
详解python播放音频的三种方法
2021-12-16 09:19:11
asp 快钱网关接口 支付宝接口 财付通接口代码
2011-03-08 10:55:00
SQL Server的BUILTIN\\Administrators用户
2009-02-04 13:51:00
TensorFlow实现Batch Normalization
2023-02-03 05:20:15
![](https://img.aspxhome.com/file/2023/8/79718_0s.png)
Python+selenium 获取一组元素属性值的实例
2021-06-06 02:28:27
使用PowerShell实现批量修改或替换文件名
2023-02-08 05:02:10
![](https://img.aspxhome.com/file/2023/0/120920_0s.png)
详解Go 将在下个版本支持新型排序算法pdqsort
2023-10-07 23:49:40
![](https://img.aspxhome.com/file/2023/8/103028_0s.png)
go smtp实现邮件发送示例详解
2023-06-23 22:05:14
![](https://img.aspxhome.com/file/2023/0/72730_0s.png)
Android ProgressBar进度条和ProgressDialog进度框的展示DEMO
2023-11-20 01:15:43
![](https://img.aspxhome.com/file/2023/1/95001_0s.jpg)
键盘上下键的操作代码(选择)
2008-06-10 12:28:00
注册表单的规则——读《Patterns for Sign Up &Ramp Up》
2008-07-17 12:51:00
python:按行读入,排序然后输出的方法
2021-09-15 06:13:58
Python 一句话生成字母表的方法
2022-03-15 06:49:47
python+Matplotlib 绘制带置信区间的折线图
2022-04-29 06:23:40
![](https://img.aspxhome.com/file/2023/0/80390_0s.jpg)
css可以给img元素设置背景图
2008-09-29 15:35:00
黑科技 Python脚本帮你找出微信上删除你好友的人
2021-09-04 04:07:08
![](https://img.aspxhome.com/file/2023/4/101484_0s.png)