Python log 日志的使用

import logging
import logging.handlers
import os
import time


class Logs(object):
    def __init__(self):
        self.logger = logging.getLogger("")
        # 设置输出的等级
        LEVELS = {'NOSET': logging.NOTSET,
                  'DEBUG': logging.DEBUG,
                  'INFO': logging.INFO,
                  'WARNING': logging.WARNING,
                  'ERROR': logging.ERROR,
                  'CRITICAL': logging.CRITICAL}
        # 创建文件目录
        logs_dir = "logs"
        if os.path.exists(logs_dir) and os.path.isdir(logs_dir):
            pass
        else:
            os.mkdir(logs_dir)
        # 修改log保存位置
        timestamp = time.strftime("%Y-%m-%d", time.localtime())
        log_filename = '%s.log' % timestamp
        log_file_path = os.path.join(logs_dir, log_filename)
        rotating_file_handler = logging.handlers.RotatingFileHandler(filename=log_file_path,
                                                                     maxBytes=1024 * 1024 * 5,
                                                                     backupCount=5)
        # 设置输出格式
        formatter = logging.Formatter('[%(asctime)s] '
                                      '[%(levelname)s] '
                                      '%(message)s',
                                      '%Y-%m-%d %H:%M:%S')
        # formatter = logging.Formatter('%(asctime)s - %(filename)s:[line:%(lineno)s] - %(name)s - %(message)s')
        rotating_file_handler.setFormatter(formatter)
        # 控制台句柄
        console = logging.StreamHandler()
        console.setLevel(logging.NOTSET)
        console.setFormatter(formatter)
        # 添加内容到日志句柄中
        self.logger.addHandler(rotating_file_handler)
        self.logger.addHandler(console)
        self.logger.setLevel(logging.NOTSET)

    def debug(self, message):
        self.logger.debug(message)

    def info(self, message):
        self.logger.info(message)

    def warning(self, message):
        self.logger.warning(message, exc_info=1)

    def error(self, message):
        self.logger.error(message, exc_info=1)



import multiprocessing
import sys
import logging.handlers

# 日志
# 方便的调试,可以用logging
logger = multiprocessing.get_logger()
logger.setLevel(logging.INFO)
# 创建一个handler,用于写入日志文件
fh = logging.handlers.RotatingFileHandler("log1.log", maxBytes=1024 * 1024, backupCount=5)
fh.setLevel(logging.DEBUG)
fe = logging.handlers.RotatingFileHandler("error.log", maxBytes=1024 * 1024, backupCount=5)
fe.setLevel(logging.ERROR)
# 定义handler的输出格式
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
fh.setFormatter(formatter)
fe.setFormatter(formatter)
logger.addHandler(fh)
logger.addHandler(fe)


def worker():
    print('Doing some work')
    logger.info("INFO in worker")
    logger.debug("DEBUG in worker")
    logger.error("ERROR in worker")
    logger.warning("WARNING in worker")
    logger.critical("CRITICAL in worker")

    sys.stdout.flush()


if __name__ == '__main__':
    multiprocessing.log_to_stderr()
    p = multiprocessing.Process(target=worker)
    p.start()
    p.join()

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值