python 日志打印

参考文章

python loggin 教程

简单样例

# 保存日志到文件  example.log ,日志级别 DEBUG
logging.basicConfig(filename='example.log', filemode='w', level=logging.DEBUG)
logging.debug('This message should go to the log file')
logging.info('So should this')
logging.warning('And this, too')

运行后生成日志文件 example.log ,内容如下:

DEBUG:root:This message should go to the log file
INFO:root:So should this
WARNING:root:And this, too

如果没有下面的语句

logging.basicConfig(filename='example.log', filemode='w', level=logging.DEBUG)

则直接在控制台打印

WARNING:root:And this, too

两次内容不一样是不是很奇怪。这个跟日志打印级别有关。

下面描述了标准级别及其适用性(按照严重程度从低到高的顺序)

水平使用时
DEBUG详细信息,通常仅在诊断问题时才需要。
INFO确认一切正常。
WARNING表示发生了意外情况,或者表示在不久的将来出现了某些问题(例如“磁盘空间不足”)。该软件仍按预期运行。
ERROR由于存在更严重的问题,该软件无法执行某些功能。
CRITICAL严重错误,表明程序本身可能无法继续运行。

logging 默认级别为WARNING,这意味着将仅跟踪此级别及更高级别的事件,所以上面控制台只打印 WARNING 的日志。

高级样例

日志同时打印到控制台和文件中

import logging
import logging.handlers

'''
日志模块
'''
LOG_FILENAME = '../jd_seckill.log'
logger = logging.getLogger()


def set_logger():
    logger.setLevel(logging.INFO)
    # 输出格式:asctime 时间,process 进程Id,threadName 线程名,pathname 文件路径,
    # lineno 行数,levelname 日志等级, message 消息
    formatter = logging.Formatter('%(asctime)s - %(process)d-%(threadName)s - '
                                  '%(pathname)s[line:%(lineno)d] - %(levelname)s: %(message)s')
    # 控制台打印
    console_handler = logging.StreamHandler()
    console_handler.setFormatter(formatter)
    logger.addHandler(console_handler)

    # 文件日志打印
    file_handler = logging.handlers.RotatingFileHandler(
        LOG_FILENAME, maxBytes=10485760, backupCount=5, encoding="utf-8")
    file_handler.setFormatter(formatter)
    logger.addHandler(file_handler)


set_logger()

logger.debug("我是 debug 消息 ")
logger.info("我是 info 消息 ")
logger.warning("我是 warning 消息 ")
logger.error("我是 error 消息 ")
logger.critical("我是 critical 消息 ")

控制台日志:

2021-01-04 18:00:22,160 - 12660-MainThread - D:/Workspace/jd_logger.py[line:28] - INFO: 我是 info 消息 
2021-01-04 18:00:22,160 - 12660-MainThread - D:/Workspace/jd_logger.py[line:29] - WARNING: 我是 warning 消息 
2021-01-04 18:00:22,160 - 12660-MainThread - D:/Workspace/jd_logger.py[line:30] - ERROR: 我是 error 消息 
2021-01-04 18:00:22,160 - 12660-MainThread - D:/Workspace/jd_logger.py[line:31] - CRITICAL: 我是 critical 消息 

jd_seckill.log 日志文件内容:
在这里插入图片描述

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值