網(wǎng)站首頁 編程語言 正文
python利用logging模塊實(shí)現(xiàn)根據(jù)日志級別打印不同顏色日志的代碼案例_python
作者:eliwang ? 更新時(shí)間: 2022-12-27 編程語言logger:日志器對象,可通過logging.getLogger()方法獲取
handler:處理器對象,將日志信息輸出到指定位置,可通過logger.addHandler()方法進(jìn)行添加
formatter:格式器對象,輸出格式化日志字符串
有時(shí)候同一個(gè)應(yīng)用程序有不同的日志需求,比如將error級別的日志在控制臺輸出,critical級別的日志寫入日志文件中,這就需要不同的handler來實(shí)現(xiàn),然后均通過logger.addHandler()方法進(jìn)行添加
代碼:
# coding:utf-8
import logging
import colorlog
class Log:
def __init__(self,name=None,log_level=logging.DEBUG):
# 獲取logger對象
self.logger = logging.getLogger(name)
# 避免重復(fù)打印日志
self.logger.handlers = []
# 指定最低日志級別:(critical > error > warning > info > debug)
self.logger.setLevel(log_level)
# 日志格化字符串
console_fmt = '%(log_color)s%(asctime)s-%(threadName)s-%(filename)s-[line:%(lineno)d]-%(levelname)s: %(message)s'
file_fmt = '%(asctime)s-%(threadName)s-%(filename)s-[line:%(lineno)d]-%(levelname)s: %(message)s'
# 控制臺輸出不同級別日志顏色設(shè)置
color_config = {
'DEBUG': 'cyan',
'INFO': 'green',
'WARNING': 'yellow',
'ERROR': 'red',
'CRITICAL': 'purple',
}
console_formatter = colorlog.ColoredFormatter(fmt=console_fmt,log_colors=color_config)
file_formatter = logging.Formatter(fmt=file_fmt)
# 輸出到控制臺
console_handler = logging.StreamHandler()
# 輸出到文件
file_handler = logging.FileHandler(filename=name,mode='a',encoding='utf-8')
# 設(shè)置日志格式
console_handler.setFormatter(console_formatter)
file_handler.setFormatter(file_formatter)
# 處理器設(shè)置日志級別,不同處理器可各自設(shè)置級別,默認(rèn)使用logger日志級別
# console_handler.setLevel(logging.WARNING)
file_handler.setLevel(logging.ERROR) # 只有error和critical級別才會寫入日志文件
# logger添加處理器
self.logger.addHandler(console_handler)
self.logger.addHandler(file_handler)
def debug(self,message):
self.logger.debug(message)
def info(self,message):
self.logger.info(message)
def warning(self,message):
self.logger.warning(message)
def error(self,message):
self.logger.error(message)
def critical(self,message):
self.logger.critical(message)
if __name__ == '__main__':
# 控制臺只會顯示warning及以上級別日志信息,而log.txt文件中則會記錄error及以上級別日志信息
log = Log(name='log.txt',log_level=logging.WARNING)
log.debug('debug')
log.info('info')
log.warning('warning')
log.error('error')
log.critical('critical')
最終控制臺按照指定顏色輸出warning以上級別日志內(nèi)容:
log.txt文件中寫入了error及critical級別日志內(nèi)容:
補(bǔ)充(python自帶的格式化字符串):
原文鏈接:https://www.cnblogs.com/eliwang/p/16708787.html
相關(guān)推薦
- 2022-10-12 pandas學(xué)習(xí)之df.fillna的具體使用_python
- 2022-03-15 azkaban.utils.UndefinedPropertyException: Missing
- 2022-07-15 Qt各種字符轉(zhuǎn)換的實(shí)現(xiàn)示例_C 語言
- 2023-12-14 如何查看瀏覽器內(nèi)核版本
- 2022-09-01 MongoDB對Document(文檔)的插入、刪除及更新_MongoDB
- 2021-12-06 樹莓派4B+EdgeX+MQTT的填坑之旅
- 2022-10-16 Python中re模塊:匹配開頭/結(jié)尾(^/$)_python
- 2022-02-17 H5移動端點(diǎn)擊出現(xiàn)背景藍(lán)色框的解決方案
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支