logging 模块简单使用记录

news2024/11/16 0:47:22

文章目录

    • 1、logging 基本架构
    • 2、Logger 日志记录器及基础配置
      • 2.1 基础配置函数logging.basicConfig()
    • 3、Handler 日志处理器 、 Formatter 格式化器和 Filterer 日志过滤器
      • 3.1 logging 模块提供的 Handler:[官方网址](https://docs.python.org/2/howto/logging.html#useful-handlers)
    • 4、输出python 错误信息 tracebak
    • 5、使用配置文件,动态地配置日志记录器、处理器、过滤器和格式化器
      • 5.1 创建配置文件setting.py
      • 5.2 使用配置

1、logging 基本架构

  • LogRecord类: 一个实例就是一条日志记录信息

  • Logger 类: 生成日志记录(LogRecord)的主类,按照相应配置和调用的方法生成一条条不同日记记录(LogRecord)

  • Formatter类: 控制日志输出格式的类,格式化日志文本内容

  • Filter 类: 过滤日志记录(LogRecord)的类,过滤日志的级别或包含某些关键字的日志

  • Handler 类: 处理日志记录(LogRecord)的类,修改日志记录格式(通过Formatter),控制日志输出位置(控制台、文件、远程服务器等)

2、Logger 日志记录器及基础配置

2.1 基础配置函数logging.basicConfig()

logging.basicConfig(args) 用于快速设置日志系统基本配置,若不设置,默认采用BASIC_FORMAT文本格式输出控制台sys.stderr

​ args配置参数:

  • filename: 日志输出文件名,若指定则默认启用FileHandler

  • filemode: 若日志输出到文件,指定日志文件写入方式(a:追加;w:覆盖写入)

  • encoding: 若日志输出文件,指定filename日志文件编码

  • format: 日志记录输出文本格式

    • %(levelno)s:打印日志级别的数值
    • %(levelname)s:打印日志级别的名称
    • %(pathname)s:打印当前执行程序的路径,其实就是sys.argv[0]
    • %(filename)s:打印当前执行程序名
    • %(funcName)s:打印日志的当前函数
    • %(lineno)d:打印日志的当前行号
    • %(asctime)s:打印日志的时间
    • %(thread)d:打印线程ID
    • %(threadName)s:打印线程名称
    • %(process)d:打印进程ID
    • %(processName)s:打印进程名称
    • %(module)s:打印模块名称
    • %(name)s:日志记录器的名称
    • %(message)s:打印日志信息的内容
  • datefmt: 日志记录输出日期格式 ‘%Y-%m-%d %H:%M:%S’

  • style: 与format一起使用,指定文本格式化时占位符(‘%’, ‘{’, ‘$’),默认%

  • level: 日志级别

    • logging.DEBUG
    • logging.INFO
    • logging.WARNING
    • logging.ERROR
    • logging.CRITICAL
  • stream: 指定日志输出的StreamHandler,如 sys.stdout、sys.stderr

import logging
import sys

# 日志配置
logging.basicConfig(format='{asctime}:{levelname} {name}.py {message}', 
                    datefmt='%Y-%m-%d %H:%M:%S',
                    style='{',
                    level=logging.DEBUG,
                    stream=sys.stdout
                   )

# 注: logging.basicConfig()函数配置,对于直接使用logging.Logger(name)类创建的日志logger对象不起作用,需要单独设置特定的日志处理器和格式化器。
# logging.basicConfig() 的主要目的是为应用程序设置基本的日志配置,它只在调用时对 “根日志记录器” 起作用,并且只会在第一次调用时生效。对于通过 logging.getLogger(name) 获取的命名日志记录器,如果未设置特定的处理器和格式化器,它们会继承 “根日志记录器” 的配置。

# 日志输出
logger = logging.getLogger('test')
logger.info('日志提示信息')
logger.warning('日志警告信息')
logger.error('日志错误信息')
logger.critical('日志严重信息')

在这里插入图片描述

3、Handler 日志处理器 、 Formatter 格式化器和 Filterer 日志过滤器

3.1 logging 模块提供的 Handler:官方网址

  • StreamHandler: 将日志消息输出到标准输出或者标准错误输出流(sys.stdout 或 sys.stderr)。
  • FileHandler: 将日志消息输出到指定的文件中。
  • RotatingFileHandler: 在达到指定的大小时自动创建新的日志文件,用于控制日志文件大小的日志处理程序。
  • TimedRotatingFileHandler: 在达到指定的时间间隔或者指定的时间时创建新的日志文件,用于按时间轮换日志文件的处理程序。
  • SocketHandler: 将日志消息发送到网络 socket 上,用于通过网络发送日志消息的处理程序。
  • DatagramHandler: 将日志消息作为 UDP 数据包发送到网络上的远程服务器,用于通过 UDP 协议发送日志消息的处理程序。
  • SysLogHandler: 将消息发送到Unix syslog守护进程,可能在远程机器上,适用于将日志记录到系统级日志的处理程序。
  • NTEventLogHandler: 将向Windows NT/2000/XP事件日志发送消息,用于在 Windows 系统上记录日志消息的处理程序。
  • SMTPHandler: 将日志消息作为电子邮件发送到指定的邮件地址,用于通过电子邮件发送日志消息的处理程序。
  • MemoryHandler: 缓存日志消息到内存中的循环缓冲区,并在达到指定的容量时触发处理程序来处理日志消息。
  • HTTPHandler: 将日志消息通过 HTTP 协议发送到远程服务器上的 Web 服务器,用于通过 HTTP 发送日志消息的处理程序。
  • NullHandler: 空处理程序,不对日志消息进行任何处理,用于在不需要实际记录日志的情况下使用。
  • WatchedFileHandler: 监视指定的文件,如果文件发生变化,将重新打开该文件并继续写入日志消息,用于监视文件并写入日志的处理程序。
import logging
import sys

logger = logging.Logger('handler 测试')   # 创建一个未绑定handler的logger对象
logger.setLevel(level=logging.WARNING)   # 设置日志记录级别

# StreamHandler  工作台输出
stream_handler = logging.StreamHandler(stream=sys.stdout)  # 重定向到控制台标准输出
stream_handler.setLevel(logging.INFO)
formatter = logging.Formatter(fmt='{asctime}:{levelname} {name}.py {message}',datefmt='%Y-%m-%d %H:%M:%S',style='{')
stream_handler.setFormatter(formatter)

# filterer 日志过滤器
class MyFilter(logging.Filter):
    def filter(self,record):
        return True if '000' not in record.msg else False  # 控制台输出过滤掉含“000"日志
stream_handler.addFilter(MyFilter())


# FileHandler 日志文件输出
file_handler = logging.FileHandler(filename='./data/log.out',encoding='utf-8')  # 日志输出文件
file_handler.setLevel(logging.INFO)
formatter1 = logging.Formatter(fmt='{asctime}:{levelname} {message}',datefmt='%Y-%m-%d %H:%M:%S',style='{')
file_handler.setFormatter(formatter1)


# 添加处理器
logger.addHandler(stream_handler)
logger.addHandler(file_handler)

a = logger.info('日志提示信息')
logger.warning('日志警告信息')
logger.error('日志错误信息')
logger.critical('0000日志严重信息')
  • 控制台输出

    外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传

  • 日志输出文件

    在这里插入图片描述

注: 一个logger日志记录器可以添加多个日志处理器,handler日志处理器和logger日志记录器 同时设置 level 以最高的级别为准

4、输出python 错误信息 tracebak

import logging

logger = logging.getLogger('追踪错误')

try:
    res = 2/0
except Exception:
    logging.error('failed',exc_info=True)  # 设置参数exc_info
    

在这里插入图片描述

5、使用配置文件,动态地配置日志记录器、处理器、过滤器和格式化器

5.1 创建配置文件setting.py

import sys
# logging 配置
LOGGING = {
    'version':1,
    'disable_existing_loggers':False,
    'formatters':{
        # 定义格式化器
        'formatter1':{
            'format':'{asctime}:{levelname} 被调用 {message}',
            'style':'{'  
        },
         'formatter2':{
            'format':'{asctime}:{levelname}-{module}.py-{message}',
            'style':'{'  
        }
    },
    
    'handlers':{
        # 定义日志处理器
        'handler1':{
            'level':'DEBUG',
            'class':'logging.StreamHandler',
            'formatter':'formatter1',
            'stream':sys.stdout
        },
        'handler2':{
            'level':'DEBUG',
            'class':'logging.FileHandler',
            'formatter':'formatter2',
            'filename':'./data/log.out'
        }  
    },
    
    'loggers':{
        # 自定义日志记录器
        'logger1':{
            'level':'INFO',
            'handlers':['handler1','handler2'],
            'propagate':False # 设置为0表示不传播日志消息到父级Logger 
        },
        'logger2':{
            'level':'INFO',
            'handlers':['handler1'],
            'propagate':False # 设置为0表示不传播日志消息到父级Logger            
        }
        
    },

}

5.2 使用配置

import logging 
from setting import LOGGING

# 加载配置
logging.config.dictConfig(LOGGING)

logger = logging.getLogger('logger2') # 调用配置文件中logger2 日志记录器
logger.info('调用logger2')

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1869633.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

拍照就用华为Pura 70系列,后置真实感人像轻松出片!

平时喜欢用手机记录生活的人是不是总有个烦恼,想要拍出媲美单反的完美人像,又怕照片失真,经过近期对手机摄影的探索,我发现了华为Pura70系列的真实感人像之美,它给予每个热爱生活的人直面镜头的自信,记录真…

基于AiService实现智能文章小助手

顾名思义,这个应用就是希望能利用大模型的能力来帮助我写文章,那这样一个应用该如何利用LangChain4j来实现呢?接下来我们来利用AiService进行实现。 AiService代理 首先,我们定义一个接口Writer,表示作家&#xff1a…

002 使用kibana操作ElasticSearch7.x

文章目录 4.使用kibana操作es4.1.文档操作1.put方式发送数据2.post方式发送数据3.查看索引文档 GET4.更新文档 POST5.删除文档&索引 DELETE6.批量添加数据_bulk 4.2.Query DLS(查询领域对象语言)1.url 检索数据语法2.查询所有数据3.查询全部数据并排序4.查询全部数据排序并…

面试-java异常体系

1.java异常体系 error类是指与jvm相关的问题。如系统崩溃,虚拟机错误,内存空间不足。 非runtime异常不处理,程序就没有办法执行。 一旦遇到异常抛出,后面的异常就不会进行。 (1)常见的error以及exception 2.java异常要点分析…

安全感爆棚,锁定六氟化硫SF6气体泄漏报警监测系统

一、概述 六氟化硫SF6气体已有百年历史,它是法国两位化学家Moissan和Lebeau于1900年合成的人造惰性气体, 1947年提供商用。当前SF6气体主要用于电力工业中。化学性质稳定。微溶于水、醇及醚,可溶于氢氧化钾。不与氢氧化钠、液氨、盐酸及水起…

【Knowledge Graph Context-Enhanced Diversified Recommendation(MSDM2024)】

Knowledge Graph Context-Enhanced Diversified Recommendation 摘要 推荐系统(RecSys)领域已被广泛研究,以通过利用用户的历史交互来提高准确性。 尽管如此,这种对准确性的持续追求常常导致多样性的减少,最终导致众所…

阿里Qwen-2成全球开源大模型排行榜第一,中国处于领导地位。

6月27日凌晨,全球著名开源平台huggingface(笑脸)的联合创始人兼首席执行官Clem在社交平台宣布,阿里最新开源的Qwen2-72B指令微调版本,成为开源模型排行榜第一名。 他表示,为了提供全新的开源大模型排行榜…

KubeCon 香港:移动云与云猿生联合议题《在没有专用 Operator 的情况下管理数据库集群》

KubeCon CloudNativeCon 开源峰会 AI_dev 中国大会将于 2024 年 8 月 21 日至 23 日在香港举行。来自全球的云原生技术专家与爱好者在这里相会,探讨云原生领域的技术创新与最佳实践。此外,本次 KubeCon CloudNativeCon 和开源峰会将与 AI_dev&#x…

使用ESP32开发一款chat机器人

目的:使用语音对话的方式实现和ai机器人对话,核心硬件如下 主板: ESP32S3 语音(拾音器-麦克风):INMP441全向麦克风模块 购买记录: https://oshwhub.com/shukkkk/esp32s3_tft_mp3

隧道管廊人员定位系统的应用与发展

随着城市建设的不断发展,地下管廊和隧道工程的规模和数量也在快速增长。隧道工程处于复杂、封闭的环境中,人员的安全管理成为一项重要任务。隧道管廊人员定位系统作为一种先进的技术手段,可以实时追踪人员位置,提供实时监控和安全…

clip系列改进Lseg、 group ViT、ViLD、Glip

Lseg 在clip后面加一个分割head,然后用分割数据集有监督训练。textencoder使用clip,frozen住。 group ViT 与Lseg不同,借鉴了clip做了真正的无监督学习。 具体的通过group block来做的。使用学习的N个group token(可以理解为聚类…

数字社交的领航者:解析Facebook的引领作用

在当今数字化社会中,社交网络已经成为了人们日常生活不可或缺的一部分。而在众多社交平台中,Facebook凭借其巨大的用户基础和创新的技术应用,被公认为数字社交领域的领航者之一。本文将深入解析Facebook在数字社交中的引领作用,探…

Eclipse代码编辑器自主配色

1. 打开 Eclipse 的设置 - Java - Editor - Syntax Coloring 2. 自定义各种类型的颜色,例如: 1. Interface 勾选,设置为紫色 2. Class 勾选,设置为淡蓝色 3. Abstract classes 勾选,有自己默认的颜色 …

Web渗透:文件包含漏洞(part.1)

"文件包含漏洞"(File Inclusion Vulnerability)是一种常见的Web应用程序漏洞,攻击者可以通过这个漏洞在目标系统上包含或执行任意文件。主要有两种类型的文件包含漏洞: 本地文件包含(Local File Inclusion, …

Django(根据Models中模型类反向生成数据库表)—— python篇

一、数据库的配置 1、 django默认支持 sqlite,mysql, oracle,postgresql数据库。 sqlite:django默认使用sqlite的数据库,默认自带sqlite的数据库驱动 , 引擎名称:django.db.backends.sqlite3 mysql:引擎名称&#xff…

克服指标管理痛点,实现数据价值最大化

在当下的企业管理中,由于数据量的激增,管理方式逐渐从基于经验转向基于数据。在此过程中,我们能够通过数据探查业务情况、分析数据,从而获取更优的决策支持数据。这通常通过数据报表或分析平台来实现,对于临时性场景&a…

基于YOLOv10的车辆统计跟踪与车速计算应用

文章目录 1、前言2、安装运行环境3、下载v10s模型4、代码实现5、代码详读5.1、导入必要的库5.2、识别车辆5.3、读取视频文件5.4、创建视频写入器5.5、车速计算5.6、统计车辆5.7、应用跟踪5.8、视频处理 6、目标检测系列文章 1、前言 在智能交通系统(ITS&#xff09…

Does a vector database maintain pre-vector chunked data for RAG systems?

题意:一个向量数据库是否为RAG系统维护预向量化分块数据? 问题背景: I believe that when using an LLM with a Retrieval-Augmented Generation (RAG) approach, the results retrieved from a vector search must ultimately be presented…

提升用户转化率秘诀!Xinstall的H5拉起应用技术让您领先一步!

在移动互联网时代,App的推广和运营面临着诸多挑战。其中,H5页面如何高效、便捷地拉起应用,成为了一个亟待解决的问题。今天,我们就来谈谈如何利用Xinstall品牌,轻松解决这一痛点,提升用户体验,助…

ONLYOFFICE桌面编辑器8.1:办公体验新升级

引入 当今时代办公三件套已经成为我们日常生活中不可或缺的一部分了,但是说到办公软件不知道大家会首先想到那些产品 office 亦或是 WPS。最近也发布了 8.1 新版本,更新了一些新功能今天我们就来评测评测。 文章目录 引入一、ONLYOFFICE 是什么&#xff…