Spaces:
Running
on
Zero
Running
on
Zero
File size: 941 Bytes
4c954ae |
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 |
# 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
|