o
    e~
                     @   sR   d Z ddlZddlZddlZddlZddlmZ i Ze	 ddej
fddZdS )zh
This code is refer from:
https://github.com/WenmuZhou/PytorchOCR/blob/master/torchocr/utils/logging.py
    NZppocrc           	      C   s   t | }| tv r|S tD ]}| |r|  S qt jddd}t jtjd}|| |	| |durZt
 dkrZtj|d }tj|dd t |d	}|| |	| t
 dkrf|| n|t j dt| < d
|_|S )a   Initialize and get a logger by name.
    If the logger has not been initialized, this method will initialize the
    logger by adding one or two handlers, otherwise the initialized logger will
    be directly returned. During initialization, a StreamHandler will always be
    added. If `log_file` is specified a FileHandler will also be added.
    Args:
        name (str): Logger name.
        log_file (str | None): The log filename. If specified, a FileHandler
            will be added to the logger.
        log_level (int): The logger level. Note that only the process of
            rank 0 is affected, and other processes will set the level to
            "Error" thus be silent most of the time.
    Returns:
        logging.Logger: The expected logger.
    z1[%(asctime)s] %(name)s %(levelname)s: %(message)sz%Y/%m/%d %H:%M:%S)datefmt)streamNr   T)exist_okaF)logging	getLoggerlogger_initialized
startswith	FormatterStreamHandlersysstdoutsetFormatter
addHandlerdistZget_rankospathsplitmakedirsFileHandlersetLevelERROR	propagate)	nameZlog_file	log_levelloggerZlogger_name	formatterZstream_handlerZlog_file_folderfile_handler r   MD:\Projects\ConvertPro\env\Lib\site-packages\paddleocr/ppocr/utils/logging.py
get_logger   s4   





r    )__doc__r   r   r   	functoolsZpaddle.distributeddistributedr   r   	lru_cacheDEBUGr    r   r   r   r   <module>   s   