logging打印台和文本双输出

参考以下博客修改的.

#https://www.cnblogs.com/SnowPhoenix/p/15201097.html
#https://blog.csdn.net/colinlee19860724/article/details/90965100

#logging_t.py
import logging
import sys

def config_logging(file_name: str, console_level: int=logging.DEBUG, file_level: int=logging.INFO):
    file_handler = logging.FileHandler(file_name, mode='w', encoding="utf8")
    file_handler.setFormatter(logging.Formatter(
        '%(asctime)s [%(levelname)s] %(module)s.%(lineno)d %(name)s:\t%(message)s'
        ))
    file_handler.setLevel(file_level)

    console_handler = logging.StreamHandler(sys.stdout)
    console_handler.setFormatter(logging.Formatter(
        '[%(asctime)s %(levelname)s %(filename)s(%(lineno)d) %(funcName)s %(name)s]:%(message)s',
        datefmt="%Y/%m/%d %H:%M:%S"
        ))
    console_handler.setLevel(console_level)
    #logger = logging.getLogger(__name__)#不管用.必须在main中才能用
    return logging.basicConfig(
        level=min(console_level, file_level),
        handlers=[console_handler,file_handler],
        )

if __name__ == '__main__':
    config_logging("test0.log")
    logging.debug("debug")
    logging.info("info")
    logging.warning("warning")
    logging.critical("critical")

    logger = logging.getLogger(__name__)
    logger.debug("debug")
    logger.info("info")
    logger.warning("warning")
    logger.critical("critical")

因为我需要控制台和文本双输出的需求.
一般,我把logg单独放在一个文件中. 使用的时候调用这个函数.

#xx.py

from logging_t import config_logging
import logging
config_logging("test.log",console_level=logging.DEBUG, file_level=logging.INFO)
logger = logging.getLogger(__name__)
logger.debug("debug")
logger.debug(a) if logger else None
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值