kaiwu.common._logger 源代码

"""
日志
"""

import logging
import sys

# 模块级单例初始化(Python保证模块导入时只执行一次)
_root_logger = logging.getLogger("kaiwu")
_root_logger.setLevel(logging.INFO)
_root_logger.propagate = False  # 禁止向上传播

# 统一配置控制台Handler
_console_handler = logging.StreamHandler(sys.stdout)
_console_handler.setLevel(logging.NOTSET)  # 处理所有级别

# 标准化格式
_formatter = logging.Formatter(
    "[%(asctime)s] [%(levelname)-8s] [%(name)s:%(lineno)d] - %(message)s",
    datefmt="%Y-%m-%d %H:%M:%S",
)
_console_handler.setFormatter(_formatter)

# 确保只添加一次Handler
if not _root_logger.handlers:
    _root_logger.addHandler(_console_handler)


[文档] def set_log_level(level): """设置SDK日志输出级别 SDK默认输出INFO级别以上的日志,可通过此函数修改输出级别 Args: level (str or int): 支持传入 logging.ERROR, logging.INFO、... 、logging.ERROR或字符串ERROR、INFO、... 、ERROR Examples: >>> import kaiwu as kw >>> kw.common.set_log_level(level="DEBUG") # doctest: +SKIP """ level = level.upper() if isinstance(level, str) else level _root_logger.setLevel(level)
[文档] def set_log_path(path="/tmp/output.log"): """设置SDK日志输出文件路径, 需要绝对路径. Args: path (str): 自定义日志文件输出路径 Examples: >>> import kaiwu as kw >>> kw.common.set_log_path("/tmp/output.log") # doctest: +SKIP """ file_handler = logging.FileHandler(path) file_handler.setFormatter(_formatter) _root_logger.addHandler(file_handler)