Python日志处理模块logging用法解析
作者:Surpassme 发布时间:2021-01-05 14:45:55
logging模块是Python内置的标准模块,主要用于输出运行日志,可以设置输出日志的等级、日志保存路径、日志文件回滚等。
其主要优点如下:
1.可以通过设置不同的日志等级,在release版本中只输出重要信息,而不必显示大量的调试信息;
2.尤其是代码运行在服务器上,当出现问题时可以通过查看日志进行分析。
logging模块基本使用:
设置logger名称
logger = logging.getLogger(log_name)
设置log级别
logger.setLevel(logging.info)
创建一个handler,用于写入日志文件
fh = logging.FileHandler(log_file)
设置日志级别,默认为logging.WARNING
fh.setLevel(logLevel[log_level])
定义handler的输出格式
formatter = logging.Formatter('%(asctime)s %(name)s [line:%(lineno)d] %(levelname)s %(message)s')
fh.setFormatter(formatter)
添加handler
logger.addHandler(fh)
format
%(levelno)s: 打印日志级别的数值
%(levelname)s: 打印日志级别名称
%(pathname)s: 打印当前执行程序的路径,其实就是sys.argv[0]
%(filename)s: 打印当前执行程序名
%(funcName)s: 打印日志的当前函数
%(lineno)d: 打印日志的当前行号
%(asctime)s: 打印日志的时间
%(thread)d: 打印线程ID
%(threadName)s: 打印线程名称
%(process)d: 打印进程ID
%(message)s: 打印日志信息
示例代码如下:
import logging
import datetime
import os
# 定义日志级别字典
logLevelDic={
"info":logging.INFO,
"debug":logging.DEBUG,
"warning":logging.WARNING,
"error":logging.ERROR
}
# 日志保存路径
logSavePath=os.path.join(os.getcwd(),"logs")
if not os.path.exists(logSavePath):
os.makedirs(logSavePath,exist_ok=True)
# 当前时间
curTime=datetime.datetime.now().strftime("%Y%m%d")
# 保存的日志的完整名称
logFile=os.path.join(logSavePath,curTime+".SADCI.log")
# 日志级别
logLevel="error"
class Logger:
def __init__(self,logFile=logFile,logLevel=logLevelDic["error"]):
self.logFile=logFile
self.logLevel=logLevel
# 设置logger名称
self.logger=logging.getLogger()
# 设置参数级别
self.logger.setLevel(self.logLevel)
self.formatter=logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
# 判断handlers是否存在
if not self.logger.handlers:
# 写入控制台
consoleStream=logging.StreamHandler()
consoleStream.setLevel(self.logLevel)
consoleStream.setFormatter(self.formatter)
# 写入文件
fileStream=logging.FileHandler(self.logFile,mode="a")
fileStream.setLevel(self.logLevel)
fileStream.setFormatter(self.formatter)
self.logger.addHandler(consoleStream)
self.logger.addHandler(fileStream)
def MyLogger():
return Logger(logFile=logFile,logLevel=logLevelDic[logLevel]).logger
if __name__ == '__main__':
MyLogger().error("test logg")
来源:https://www.cnblogs.com/surpassme/p/12787153.html
猜你喜欢
- 核心代码: header("Expires: Mon, 26 Jul 1997 05:00:00 GMT"); head
- 我们经常会有对图像边缘做扩展的需求.比如希望卷积后得到的矩阵大小不变希望改变图像大小,但是不改变宽高比opencv实现opencv中使用co
- 注意,在改变数值之前锁定应用,确保一段时间里只有一个客户执行该语句。<SCRIPT LANGUAGE="VBScr
- 活在当下的程序员应该都听过“面向对象编程”一词,也经常有人问能不能用一句话解释下什么是“面向对象编程”,我们先来看看比较正式的说法。把一组数
- CSS 中的 position 属性可以很容易的将指定的元素定位到理想的位置。但在使用这一属性时需要注意,尤其是在表格元素中。为了说明此问题
- 本文实例讲述了Python基于time模块求程序运行时间的方法。分享给大家供大家参考,具体如下:要记录程序的运行时间可以利用Unix系统中,
- parent.html 中的代码为:<iframe marginwidth="0"
- 如果只是因为浏览者改变了浏览器的设置,或者因为浏览器不兼容,使自己精心制作的网页变得“面目全非”,那多令人沮丧!下面我们以网页爱好者的常用工
- 一、SeabornSeaborn 建于 matplotlib 库的之上。它有许多内置函数,使用这些函数,只需简单的代码行就可以创建漂亮的绘图
- reflect反射首先,我们要区分两个概念——“标识名”和&
- 一个功能的实现,可以用多种语句来实现,比如说:while语句、for语句、生成器、列表推导、内置函数等实现,然而他们的效率并不一样。写了一个
- 0.引言利用python开发,借助Dlib库进行人脸识别,然后将检测到的人脸剪切下来,依次排序显示在新的图像上;实现的效果如下图所示,将图1
- 两年前在 B 站上看到了一个宝藏 up 主,名叫 "Jannchie见齐",专门做动态条形图样式的数据可视化。做出的效果
- python逆序的三位数程序每次读入一个正3位数,然后输出按位逆序的数字。注意:当输入的数字含有结尾的0时,输出不应带有前导的0。比如输入7
- 本文实例讲述了CodeIgniter分页类pagination使用方法。分享给大家供大家参考,具体如下:controller控制器(appl
- 1.网络爬虫的基本概念网络爬虫(又称网络蜘蛛,机器人),就是模拟客户端发送网络请求,接收请求响应,一种按照一定的规则,自动地抓取互联网信息的
- 本篇介绍Python字典的常见操作。修改字典元素,如图。添加字典元素,如图。删除字典元素del方法,如图。删除字典元素clear方法,如图。
- 本文实例讲述了Python 操作mysql数据库查询之fetchone(), fetchmany(), fetchall()用法。分享给大家
- 前言在迷宫问题中,给定入口和出口,要求找到路径。本文将讨论三种求解方法,递归求解、回溯求解和队列求解。在介绍具体算法之前,先考虑将迷宫数字化
- 本文实例讲述了Python列表list操作符。分享给大家供大家参考,具体如下:#coding=utf8''''