Nan Xue
update
4c954ae
raw
history blame contribute delete
941 Bytes
# Copyright (c) Facebook, Inc. and its affiliates. All Rights Reserved.
import logging
import os
import sys
from pythonjsonlogger import jsonlogger
def setup_logger(name, save_dir, out_file='log.txt', json_format=False, rank=0):
logger = logging.getLogger(name)
logger.setLevel(logging.DEBUG)
if json_format:
formatter = jsonlogger.JsonFormatter("%(asctime)s %(name)s %(levelname)s: %(message)s")
else:
formatter = logging.Formatter("%(asctime)s %(name)s %(levelname)s: %(message)s")
if rank == 0:
ch = logging.StreamHandler(stream=sys.stdout)
ch.setLevel(logging.DEBUG)
ch.setFormatter(formatter)
logger.addHandler(ch)
if save_dir:
os.makedirs(save_dir, exist_ok=True)
fh = logging.FileHandler(os.path.join(save_dir, out_file))
fh.setLevel(logging.DEBUG)
fh.setFormatter(formatter)
logger.addHandler(fh)
return logger