logging模块的四大组件类
日志器 — Logger — 提供了应用程序可以一直使用的接口
处理器 — Handler — 将logger创建的日志记录发送到合适的目的地输出
logging.StreamHandler() 控制台输出
logging.FileHandler('filename.log', mode='a',encoding='utf-8') 指定文件输出
过滤器 — Filter — 提供了更细粒度的控制工具来决定输出那条日志记录
格式器 — Formatter — 决定日志记录的最终输出格式
使用
方式1:日志器 - 处理器(控制台处理器) - 添加处理器 - 日志输出
# 创建日志器
logger = logging.getLogger()
# 创建处理器
severHandler = logging.StreamHandler() # 控制台输出
# fileHandler = logging.FileHandler('filename.log', mode='a',encoding='utf-8') # 文件输出
# 添加处理器
logger.addHandler(severHandler)
# logger.addHandler(fileHandler)
logging.critical("这是严重错误level的日志")
logging.error("这是错误level的日志")
logging.warning("这是警告level的日志")
logging.info("这是信息level的日志")
logging.debug("这是调试信息level的日志")
方式2:日志器 - 日志器设置级别 - 处理器(控制台处理器) - 添加处理器 - 日志输出
# 创建日志器
logger = logging.getLogger()
# 日志器设置级别
logger.setLevel(logging.INFO)
# 创建处理器
severHandler = logging.StreamHandler() # 控制台输出
# fileHandler = logging.FileHandler('filename.log', mode='a',encoding='utf-8') # 文件输出
# 添加处理器
logger.addHandler(severHandler)
# logger.addHandler(fileHandler)
logging.critical("这是严重错误level的日志")
logging.error("这是错误level的日志")
logging.warning("这是警告level的日志")
logging.info("这是信息level的日志")
logging.debug("这是调试信息level的日志")
方式3:日志器 - 处理器(控制台处理器)- 处理器设置日志级别 - 添加处理器 - 日志输出
# 创建日志器
logger = logging.getLogger()
# 创建处理器
severHandler = logging.StreamHandler() # 控制台输出
# fileHandler = logging.FileHandler('filename.log', mode='a',encoding='utf-8') # 文件输出
# 处理器添加日志级别
severHandler.setLevel(logging.INFO)
# fileHandler.setLevel(logging.INFO)
# 添加处理器
logger.addHandler(severHandler)
# logger.addHandler(fileHandler)
logging.critical("这是严重错误level的日志")
logging.error("这是错误level的日志")
logging.warning("这是警告level的日志")
logging.info("这是信息level的日志")
logging.debug("这是调试信息level的日志")
方式4:日志器 - 日志器设置级别 - 处理器(控制台处理器)- 处理器设置日志级别 - 添加处理器 - 日志输出
# 两者都设置了日志级别,最终的输出级别由设置级别高的代码决定
# 创建日志器
logger = logging.getLogger()
# 日志器设置级别
logger.setLevel(logging.ERROR)
# 创建处理器
severHandler = logging.StreamHandler() # 控制台输出
# fileHandler = logging.FileHandler('filename.log', mode='a',encoding='utf-8') # 文件输出
# 处理器添加日志级别
severHandler.setLevel(logging.INFO)
# fileHandler.setLevel(logging.INFO)
# 添加处理器
logger.addHandler(severHandler)
# logger.addHandler(fileHandler)
logging.critical("这是严重错误level的日志")
logging.error("这是错误level的日志")
logging.warning("这是警告level的日志")
logging.info("这是信息level的日志")
logging.debug("这是调试信息level的日志")
方式5:日志器 - 日志器设置级别 - 处理器1(控制台处理器)- 处理器2(文件处理器) - 处理器1设置日志级别 处理器2设置日志级别 - 添加处理器 - 日志输出
# 两者都设置了日志级别,最终的输出级别由设置级别高的代码决定
# 创建日志器
logger = logging.getLogger()
# 日志器设置级别
logger.setLevel(logging.ERROR)
# 创建处理器1
severHandler = logging.StreamHandler() # 控制台输出
# 处理器1添加日志级别
severHandler.setLevel(logging.WARNING)
# 创建处理器2
fileHandler = logging.FileHandler('filename.log', mode='a',encoding='utf-8') # 文件输出
# 处理器2添加日志级别
fileHandler.setLevel(logging.INFO)
# 添加处理器1
logger.addHandler(severHandler)
# 添加处理器2
logger.addHandler(fileHandler)
logging.critical("这是严重错误level的日志")
logging.error("这是错误level的日志")
logging.warning("这是警告level的日志")
logging.info("这是信息level的日志")
logging.debug("这是调试信息level的日志")