python - logging的四大组件(日志器、处理器、过滤器、格式器)

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的日志")
  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值