【python包logging用法】


提示:以下是本篇文章正文内容,下面案例可供参考

一、导入包

import logging

二、使用步骤

logger = logging.getLogger() #包装一下
handler = logging.FileHandler(os.path.join(LOG_DIR, "ts-%s.log" % time.strftime()), encoding='UTF-8')#修改文件名和文件格式
logger.setLevel(logging.INFO)#设置日志级别
#日志级别有以下几种:
#CRITICAL, FATAL,ERROR, WARNING,WARNING, INFO,DEBUG, NOTSET,co
logging_format = logging.Formatter("[%(asctime)s] %(levelname)s ts %(message)s")
handler.setFormatter(logging_format)#设置日志输出格式,Formatter函数可根据我的须要添加想要的字段
# 创建一个Handler,用于输出到控制台
stream_handler = logging.StreamHandler()
stream_handler.setLevel(logging.INFO)
stream_handler.setFormatter(logging_format)
#输出到日志
logger.info("要输入的内容")

更详细的格式符如下:
在这里插入图片描述

  • 5
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
Python logging 模块是 Python 标准库中提供的一个日志记录工具,它可以用来记录应用程序运行时的信息,便于开发人员排查问题和分析程序性能。 使用 Python logging 模块,需要先导入 logging 模块,然后创建一个 logger 对象,通过配置 logger 的不同 handler,可以控制不同级别的日志输出到不同的地方。 下面是一个简单的使用示例: ```python import logging # 创建一个 logger 对象 logger = logging.getLogger(__name__) # 配置 logger 的 handler handler = logging.StreamHandler() formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') handler.setFormatter(formatter) logger.addHandler(handler) # 设置 logger 的日志级别 logger.setLevel(logging.INFO) # 记录日志 logger.debug('This is a debug message') logger.info('This is an info message') logger.warning('This is a warning message') logger.error('This is an error message') logger.critical('This is a critical message') ``` 在上面的示例中,我们首先创建了一个名为 `__name__` 的 logger 对象,然后配置了一个输出到标准输出的 handler,并设置了日志级别为 `INFO`。接着我们分别记录了不同级别的日志信息,最终输出的日志信息如下: ``` 2021-08-25 16:09:59,757 - __main__ - INFO - This is an info message 2021-08-25 16:09:59,757 - __main__ - WARNING - This is a warning message 2021-08-25 16:09:59,757 - __main__ - ERROR - This is an error message 2021-08-25 16:09:59,757 - __main__ - CRITICAL - This is a critical message ``` 可以看到,只有日志级别大于或等于 `INFO` 的日志信息被输出到了标准输出。如果我们希望将日志信息输出到文件,可以配置一个输出到文件的 handler,如下所示: ```python import logging # 创建一个 logger 对象 logger = logging.getLogger(__name__) # 配置 logger 的 handler handler = logging.FileHandler('example.log', mode='w') formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s') handler.setFormatter(formatter) logger.addHandler(handler) # 设置 logger 的日志级别 logger.setLevel(logging.INFO) # 记录日志 logger.debug('This is a debug message') logger.info('This is an info message') logger.warning('This is a warning message') logger.error('This is an error message') logger.critical('This is a critical message') ``` 在上面的示例中,我们将日志信息输出到了名为 `example.log` 的文件中。需要注意的是,如果文件不存在,将会被创建,如果文件已存在,将会被覆盖。如果想要追加日志信息而不是覆盖文件,可以将 `mode` 参数设置为 `'a'`。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值