SaliencyMapDemo / src /reporter.py
umyuu
リファクタリング
46c8ce2
raw
history blame
1.75 kB
# -*- coding: utf-8 -*-
"""
ログハンドラーが重複登録されるのを防ぐために1箇所で生成してログハンドラーを返します。
Example:
from src.reporter import log
log.info("message")
# 2024-05-24T12:34:56+0900#アプリ起動中
"""
import json
from logging import Logger, getLogger
import logging.config
from typing import Optional
from . import PROGRAM_NAME
class Reporter:
"""
シングルトンパターンを適用したロガークラス。
このクラスのインスタンスがまだ存在しない場合は新たに作成し、既に存在する場合はそのインスタンスを返します。
@see https://docs.python.jp/3/howto/logging-cookbook.html
"""
_instance: Optional[Logger] = None # Reporterクラスの唯一のインスタンスを保持します。
def __new__(cls):
"""
インスタンスの生成を制御します。
"""
# インスタンスがまだ存在しない場合は新たに作成します。
if not cls._instance:
logger = getLogger(PROGRAM_NAME) # ロガーを取得します。
with open(r'config.json', 'r', encoding='utf-8') as f:
config = json.load(f)
logging.config.dictConfig(config)
cls._instance = logger # 作成したロガーを保持します。
return cls._instance # 作成したまたは既存のロガーを返します。
log: Logger = Reporter() # Reporterクラスのインスタンスを取得します。
def main():
"""
Entry Point
"""
log.debug("main")
if __name__ == "__main__":
main()