热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python日志模块,loggin模块

python日

python日志模块,loggin模块

  • loggin模块
    • 日志的格式
    • 处理器种类
    • 日志格式的参数
    • 使用


loggin模块

logging库采用模块化方法,并提供了几类组件:记录器,处理程序,过滤器和格式化程序。

  • 记录器(Logger):提供应用程序代码直接使用的接口。
    ​ 相当于笔,记录日志信息。记录器可以有多个处理器

  • 处理器(Handler):将日志记录(由记录器创建)发送到适当的目的地。

    ​ 将记录器记录的日志信息发送到其他位置,处理器可以有多个,每个处理器指定一个位置

  • 筛选器(Filter):提供了更细粒度的功能,用于确定要输出的日志记录。

    ​ 筛选记录器进行筛选,通过筛选的输出其记录的日志

  • 格式器(Formatter):程序在最终输出日志记录的内容格式。

    ​ 定义日志的格式,内容格式,保存方式,切割方式

都可以根据情况定义多个

日志的格式


日志的级别日志的数字级别说明
debug10详细信息常用于调试
info20程序正常运行产生的日志
warning30警告性日志,程序仍正在运行,可能出现问题
error40错误日志,程序已经不能执行一些功能了
critical50严重错误,程序已不能运行

记录器默认日志级别为warning,处理器不做日志等级设置,会继承记录器的日志等级设置。
处理器做日志级别设置后,处理器按照处理器自身的日志级别执行。但是处理器设置的日志级别低于记录器默认日志级别时,不会生效。如果想要处理器日志级别低于记录器的默认日志级别warning,需要设置降低记录器的日志级别

处理器种类


处理器说明
logging.StreamHandler()把日志标准输出到屏幕
logging.FileHandler()把日志写入一个文件
如不能直接使用,需再次导入
import logging.handlers导入全部处理器
或from logging.handlers import RotatingFileHandler导入需要的某个处理器
logging.handlers.RotatingFileHandler()日志回滚方式,按日志大小切割备份日志
logging.handlers.TimedRotatingFileHandler()日志回滚方式,按日志使时间切割备份日志
logging.handlers.BaseRotatingHandler()基本的日志回滚方式
logging.handlers.SocketHandler()远程输出日志到TCP/IP sockets
logging.handlers.SMTPHandler()远程输出日志到邮件地址
logging.handlers.SysLogHandler()日志输出到syslog
logging.handlers.DatagramHandler()远程输出日志到UDP sockets
logging.handlers.NTEventLogHandler()远程输出日志到Windows NT/2000/XP的事件日志
logging.handlers.BufferingHandler()
logging.handlers.HTTPHandler()通过"GET"或者"POST"远程输出到HTTP服务器
logging.handlers.MemoryHandler()日志输出到内存中的指定buffer
logging.handlers.WatchedFileHandler()
logging.handlers.QueueHandler()

https://blog.csdn.net/llf_cloud/article/details/88642830

logging — Python 的日志记录工具 — Python 3.11.2 文档

日志格式的参数

format参数中可能用到的格式化信息:

参数说明
%(asctime)s字符串形式的当前时间。默认格式是 “2003-07-08 16:49:45,896”。逗号后面的是毫秒
%(name)s记录器的名字
%(levelname)s名字形式的日志级别
%(levelno)s数字形式的日志级别
%(filename)s调用日志输出函数的模块的python文件名
%(pathname)s调用日志输出函数的模块的完整路径名,即python文件的完整路径
%(module)s调用日志输出函数的模块名,可能同%(filename)s
%(funcName)s调用日志输出函数的函数名
%(lineno)d调用日志输出函数的语句所在的代码行,即句日志所在代码的行数
%(created)f当前时间,用UNIX标准的表示时间的浮点数表示,即时间戳
%(relativeCreated)d输出日志信息时的,自Logger创建以 来的毫秒数
%(thread)d线程ID。可能没有
%(threadName)s线程名。可能没有
%(process)d进程ID。可能没有
%(message)s日志的具体信息

示例:

logger = logging.getLogger("mylog")
....
formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(levelno)s - %(filename)s - %(pathname)s - %(module)s- %(funcName)s - %(lineno)d - %(created)f - %(relativeCreated)d - %(thread)d - %(threadName)s - %(process)d - %(message)s')

D:\gitee\python\venv\Scripts\python.exe D:\gitee\python\python相关\巡检脚本更新1\master2.py 2023-03-05 11:17:47,335 - mylog - INFO - 20 - pythonSsh.py - D:\gitee\python\python相关\巡检脚本更新1\pythonSsh.py - pythonSsh- myserver - 45 - 1677986267.335183 - 217 - 12912 - MainThread - 18536 - 开始建立与服务器的连接

使用

import logging
import logging.handlers# from logging.handlers import RotatingFileHandler# 记录器 处理器 过滤器 日志格式 均可根据需要设置多个# 创建记录器,记录器名字为app
logger = logging.getLogger("app")# 设置记录器记录日志的等级为INFO,即只把INFO及INFO以上的日志信息记录下来
logger.setLevel(logging.INFO)# 创建处理器,处理器可以有多个# 创建把日志屏幕输出的处理器
console_handler = logging.StreamHandler()# 创建把日志写入文件的处理器,文件未做特殊设置,会一直把日志写入此文件,不做切分
# 日志名字,日志写入方式,追加写 日志字符集,UTF-8 日志缓存 False 无缓存
file_handler = logging.FileHandler(filename="app.log", mode='a', encoding='UTF-8', delay=False)# 设置日志格式
# s前的数字8表示占8位字符,为了对齐
# 8前的-表示左对齐,默认为右对齐
# 时间 日志名 日志等级 日志信息
formatter1 = logging.Formatter('%(asctime)s - %(thread)d - %(levelname)s - %(message)s')
formatter2 = logging.Formatter('%(asctime)s - %(levelname)-8s - %(message)s')'''
formatter2 示例
2023-03-05 12:18:33,252 - INFO - this is test info
2023-03-05 12:18:33,252 - WARNING - this is test warning
2023-03-05 12:18:33,252 - ERROR - this is test error
2023-03-05 12:18:33,252 - CRITICAL - this is test critical'''
# 把日志格式添加到处理器
console_handler.setFormatter(formatter2)
file_handler.setFormatter(formatter1)# 把创建的处理器添加到处理器
logger.addHandler(console_handler)
logger.addHandler(file_handler)# 创建过滤器(过滤器非必要条件,也可以不创建)# 把记录器app 添加到过滤器
fil = logging.Filter("app")# 给记录器关联过滤器
logger.addFilter(fil)# 也可以给处理器关联过滤器
console_handler.addFilter(fil)# 打印日志的代码
logger.debug('this is test debug')
logger.info("this is test info")
logger.warning("this is test warning")
logger.error("this is test error")
logger.critical("this is test critical")# 异常日志记录
n = 'abc'
try:int(n)logger.info("test try ok")
except Exception as e:logger.exception("this test exception %s",e)#参考:
# https://blog.csdn.net/weixin_47154909/article/details/106203639

日志内容

2023-03-05 14:42:17,869 - 20472 - INFO - this is test info
2023-03-05 14:42:17,869 - 20472 - WARNING - this is test warning
2023-03-05 14:42:17,870 - 20472 - ERROR - this is test error
2023-03-05 14:42:17,870 - 20472 - CRITICAL - this is test critical
2023-03-05 14:42:17,870 - 20472 - ERROR - this test exception invalid literal for int() with base 10: 'abc'
Traceback (most recent call last):File "D:\gitee\python\python相关\日志模块logging.py", line 106, in int(n)
ValueError: invalid literal for int() with base 10: 'abc'


推荐阅读
  • 零拷贝技术是提高I/O性能的重要手段,常用于Java NIO、Netty、Kafka等框架中。本文将详细解析零拷贝技术的原理及其应用。 ... [详细]
  • 本文介绍如何使用 Python 的 DOM 和 SAX 方法解析 XML 文件,并通过示例展示了如何动态创建数据库表和处理大量数据的实时插入。 ... [详细]
  • Ansible:自动化运维工具详解
    Ansible 是一款新兴的自动化运维工具,基于 Python 开发,集成了多种运维工具(如 Puppet、CFEngine、Chef、Func 和 Fabric)的优点,实现了批量系统配置、程序部署和命令执行等功能。本文将详细介绍 Ansible 的架构、特性和优势。 ... [详细]
  • 基于Linux开源VOIP系统LinPhone[四]
    ****************************************************************************************** ... [详细]
  • 本文讨论了在进行 MySQL 数据迁移过程中遇到的所有 .frm 文件报错的问题,并提供了详细的解决方案和建议。 ... [详细]
  • 秒建一个后台管理系统?用这5个开源免费的Java项目就够了
    秒建一个后台管理系统?用这5个开源免费的Java项目就够了 ... [详细]
  • 本文详细介绍了 InfluxDB、collectd 和 Grafana 的安装与配置流程。首先,按照启动顺序依次安装并配置 InfluxDB、collectd 和 Grafana。InfluxDB 作为时序数据库,用于存储时间序列数据;collectd 负责数据的采集与传输;Grafana 则用于数据的可视化展示。文中提供了 collectd 的官方文档链接,便于用户参考和进一步了解其配置选项。通过本指南,读者可以轻松搭建一个高效的数据监控系统。 ... [详细]
  • Java Socket 关键参数详解与优化建议
    Java Socket 的 API 虽然被广泛使用,但其关键参数的用途却鲜为人知。本文详细解析了 Java Socket 中的重要参数,如 backlog 参数,它用于控制服务器等待连接请求的队列长度。此外,还探讨了其他参数如 SO_TIMEOUT、SO_REUSEADDR 等的配置方法及其对性能的影响,并提供了优化建议,帮助开发者提升网络通信的稳定性和效率。 ... [详细]
  • 如何优化MySQL数据库性能以提升查询效率和系统稳定性 ... [详细]
  • 本文介绍了如何利用 Delphi 中的 IdTCPServer 和 IdTCPClient 控件实现高效的文件传输。这些控件在默认情况下采用阻塞模式,并且服务器端已经集成了多线程处理,能够支持任意大小的文件传输,无需担心数据包大小的限制。与传统的 ClientSocket 相比,Indy 控件提供了更为简洁和可靠的解决方案,特别适用于开发高性能的网络文件传输应用程序。 ... [详细]
  • Java能否直接通过HTTP将字节流绕过HEAP写入SD卡? ... [详细]
  • Python 伦理黑客技术:深入探讨后门攻击(第三部分)
    在《Python 伦理黑客技术:深入探讨后门攻击(第三部分)》中,作者详细分析了后门攻击中的Socket问题。由于TCP协议基于流,难以确定消息批次的结束点,这给后门攻击的实现带来了挑战。为了解决这一问题,文章提出了一系列有效的技术方案,包括使用特定的分隔符和长度前缀,以确保数据包的准确传输和解析。这些方法不仅提高了攻击的隐蔽性和可靠性,还为安全研究人员提供了宝贵的参考。 ... [详细]
  • 在Android平台中,播放音频的采样率通常固定为44.1kHz,而录音的采样率则固定为8kHz。为了确保音频设备的正常工作,底层驱动必须预先设定这些固定的采样率。当上层应用提供的采样率与这些预设值不匹配时,需要通过重采样(resample)技术来调整采样率,以保证音频数据的正确处理和传输。本文将详细探讨FFMpeg在音频处理中的基础理论及重采样技术的应用。 ... [详细]
  • Nginx 反向代理配置与应用指南
    本文详细介绍了 Nginx 反向代理的配置与应用方法。首先,用户可以从官方下载页面(http://nginx.org/en/download.html)获取最新稳定版 Nginx,推荐使用 1.14.2 版本。下载并解压后,通过双击 `nginx.exe` 文件启动 Nginx 服务。文章进一步探讨了反向代理的基本原理及其在实际应用场景中的配置技巧,包括负载均衡、缓存管理和安全设置等,为用户提供了一套全面的实践指南。 ... [详细]
  • 使用Maven JAR插件将单个或多个文件及其依赖项合并为一个可引用的JAR包
    本文介绍了如何利用Maven中的maven-assembly-plugin插件将单个或多个Java文件及其依赖项打包成一个可引用的JAR文件。首先,需要创建一个新的Maven项目,并将待打包的Java文件复制到该项目中。通过配置maven-assembly-plugin,可以实现将所有文件及其依赖项合并为一个独立的JAR包,方便在其他项目中引用和使用。此外,该方法还支持自定义装配描述符,以满足不同场景下的需求。 ... [详细]
author-avatar
小晶晶妮妮宝贝
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有