日志管理 logging

日志级别,默认是waring

DEBUG 详细信息

INFO 正常运行产生的一些信息

WARNING 警告用户,虽然正常但可能会发生错误

ERROR 严重错误

CRITICAL 严重错误

简单应用

基础配置

python 复制代码
#filename,日志输出的文件,filemode='w',每次运行后会清除上次的日志内容,level=logging.DEBUG,表示只要在这个等级(包括)上的都会被输出
logging.basicConfig(filename='demo.log',filemode='w',level=logging.DEBUG)
logging.debug("debug message")
logging.info("info message")
logging.warning("warning message")
logging.error("error message")
logging.critical("critical message")

输出变量

python 复制代码
logging.basicConfig(level=logging.DEBUG)
logging.debug("姓名 %s,年龄 %d","张三",19)
logging.debug("姓名 %s,年龄 %d"%("张三",19))

设置输出格式

高级应用

loggers:记录器,提供应用程序代码直接使用的接口

Handlers:处理器,将日志输出到指定的位置

Filters:过滤器,更好选择输出的日志

Formatters:格式化器

python 复制代码
#记录器
logger = logging.getLogger("app_log")
logger.setLevel(logging.DEBUG)

#处理器
#输出控制台
consoleHandle = logging.StreamHandler()
consoleHandle.setLevel(logging.DEBUG)

#输出文件
fileHandle = logging.FileHandler(filename="addDemo.log")
fileHandle.setLevel(logging.INFO)

#formatter格式
formatter = logging.Formatter("%(asctime)s - %(name)s - %(levelname)s - %(message)s")

#设置处理的的输出格式
consoleHandle.setFormatter(formatter)
fileHandle.setFormatter(formatter)

#记录器要设置处理器
logger.addHandler(consoleHandle)
logger.addHandler(fileHandle)

#过滤器
flt = logging.Filter("cc")

#不会输出日志,被过滤掉
# logger.addFilter(flt)
#指定过滤对应的处理器
fileHandle.addFilter(flt)

logger.debug("debug message")
logger.info("info message")
logger.warning("warning message")
logger.error("error message")
logger.critical("critical message")

使用配置文件

配置文件

python 复制代码
[loggers]
keys=root,app_log

[handlers]
keys=fileHandler,consoleHandle

[formatters]
keys=simpleFormatter

[logger_root]
level=DEBUG
handlers=consoleHandle

[logger_app_log]
level=DEBUG
handlers=fileHandler,consoleHandle
qualname=app_log
propagate=0

[handler_consoleHandle]
class=StreamHandler
args=(sys.stdout,)
level=DEBUG

[handler_fileHandler]
class=handlers.TimedRotatingFileHandler
args=('app_log.log','midnight',1,0)
level=DEBUG
formatter=simpleFormatter

[formatter_simpleFormatter]
format=%(asctime)s|%(levelname)8s|%(filename)s[:%(lineno)d]|%(message)s
datefmt=%Y-%m-%d %H:%M:%S
python 复制代码
#配置文件方式处理日志
logging.config.fileConfig('logging.conf')
#记录器
rootLogger = logging.getLogger()
logger = logging.getLogger("app_log.log")

a="sss"
try:
    int(a)
except Exception as e:
    logger.exception(e)


logger.debug("debug message")
logger.info("info message")
logger.warning("warning message")
logger.error("error message")
logger.critical("critical message")
相关推荐
星空椰3 小时前
Python 面向对象高级:继承与类定义详解
开发语言·python
橙淮3 小时前
并发编程(六)
java·jvm
wunaiqiezixin3 小时前
如何在C++中创建和管理线程
c++
拽着尾巴的鱼儿3 小时前
springboot openfeign 自定义feign 接口重试机制
java·spring boot·后端
白露与泡影3 小时前
2026大厂Java面试题大全!牛客网最新版
java·开发语言
凯瑟琳.奥古斯特3 小时前
高阶子查询题目精炼
开发语言·数据库·python·职场和发展·数据库开发
雪度娃娃3 小时前
转向现代C++——在意为改写的函数添加 override
开发语言·c++
王老师青少年编程3 小时前
csp信奥赛C++高频考点专项训练之前缀和&差分 --【一维差分】:[NOIP 2018 提高组] 铺设道路
c++·前缀和·差分·csp·高频考点·信奥赛·铺设道路
星马梦缘4 小时前
aaaaa
数据结构·c++·算法
EntyIU4 小时前
JVM内存与GC笔记
java·jvm·笔记