python3 logging模块基本使用方法,解决重复打印及输出中文乱码的问题

1、logging模块使用方法

logger提供了应用程序可以直接使用的接口;

handler将(logger创建的)日志记录发送到合适的目的输出;

filter提供了细度设备来决定输出哪条日志记录;

formatter决定日志记录的最终输出格式。

import logging


logger = logging.getLogger("test")  # 定义对应的程序模块名name,默认是root
logger.setLevel(logging.DEBUG)  # 指定最低的日志级别 critical > error > warning > info > debug

consol_haddler = logging.StreamHandler()  # 日志输出到屏幕控制台
consol_haddler.setLevel(logging.INFO)  # 设置日志等级

#  这里进行判断,如果logger.handlers列表为空,则添加,否则,直接去写日志,解决重复打印的问题
if not logger.handlers:
    file_haddler = logging.FileHandler("log.txt",encoding="utf-8")  # 向文件log.txt输出日志信息,encoding="utf-8",防止输出log文件中文乱码
    file_haddler.setLevel(logging.WARNING)  # 设置输出到文件最低日志级别

    formatter = logging.Formatter("%(asctime)s %(name)s- %(levelname)s - %(message)s")
    # %(asctime)s	字符串形式的当前时间。默认格式是 “2003-07-08 16:49:45,896”。逗号后面的是毫秒
    # %(name)s 自定义的模块名

    consol_haddler.setFormatter(formatter)  # 选择一个输出格式,可以定义多个输出格式
    file_haddler.setFormatter(formatter)

    logger.addHandler(file_haddler)  # 增加指定的handler
    logger.addHandler(consol_haddler)

logger.debug("test1")
logger.info("test2")
logger.warning("test3")
logger.error("test4")

控制台输出结果如下图:

log.txt输入结果如下图:

 

这样写大家有没有发现debug及info级别的log在控制台显示出来也是红色,并没有区分。正常情况下应该显示不同颜色,比如debug--白色,info--绿色,waining--红色等等。请看我的下一篇博客。传送门:https://blog.csdn.net/xugexuge/article/details/87916020

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值