我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Python内置logging怎么使用

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Python内置logging怎么使用

这篇文章主要讲解了“Python内置logging怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python内置logging怎么使用”吧!

logging 的主要作用

提供日志记录的接口和众多处理模块,供用户存储各种格式的日志,帮助调试程序或者记录程序运行过程中的输出信息。

logging 日志等级

logging 日志等级分为五个等级,优先级从高到低依次是 :

**CRITICAL; ** 程序严重错误

**ERROR; **程序错误/部分功能错误

**WARNING; **程序有发生错误的可能

**INFO; **程序正常运行时的信息

DEBUG程序调试信息

默认的日志的记录等级为 WARNING, 即当日志的等级大于获等于 WARNING 时才会被记录。

一般常用的记录等级为 INFO,其用于记录程序的正常运行的一些信息(类似于print)。

当日志的等级达到 WARNING 以上时,表明此时程序不能正常运行;

logging 的基础函数

logging.basicConfig(**kwargs)

在没有显式的进行创建记录器(logger)时,会默认创建一个root logger,而logging.basicConfig(**kwargs) 可以创建带有默认的Formatter的streamHandle并将其添加到根日志记录器中来初始化基本配置。

比如

import logginglogging.debug('Debug code!')logging.info('Run code!')logging.warning('Watch out!')  logging.error('This is an error')logging.critical('This is a ciritical')

上面代码中 logging 并没有显式的创建logger( logging.getLogger ), 其在直接使用debug(), info(), warning(), error(), critical() 时会使用默认的 root logger,并会自动调用 自定义的或者默认的logging.basicConfig(**kwargs) 初始化 root logger。

自定义的 logging.basicConfig(**kwargs) 中的参数 有以下的主要的选项:

参数功能
filename指定保存日志的文件名,用指定文件名创建一个FileHandler,记录的日志会保存到该文件中
format指定输出的格式和内容,默认是以冒号分割的levalname、name 和 message
datefmt使用指定的日期/时间格式,与 time.strftime() 所接受的格式相同。
level指定根日志记录器级别,默认为 logging.WARNING
stream指定日志的输出流,可以指定输出到sys.stderr,std.stdout 或 文件,默认输出到sys.stderr。使用指定的流初始化StramHandler,注意:stream和filename参数不兼容,如果两者同时使用,则会引发ValueError 错误

例如下面通过自定义 logging.basicConfig(**kwargs) 来初始化 root logger 来获得DEBUG级别及以上的日志记录并保存到 log.txt 文件中。

import logginglogging.basicConfig(filename='./log.txt',                        format='%(asctime)s-%(name)s-%(levelname)s-%(message)s-%(funcName)s:%(lineno)d',                        level=logging.DEBUG)logging.debug('Debug code!')logging.info('Run code!')logging.warning('Watch out!')  logging.error('This is an error')logging.critical('This is a ciritical')

logging 的四大组件(类)

Logger

除了根记录器(root logger)外,最主要的是可以自己创建日志记录器。

通过模块级别的函数 logging.getLogger(name) 实例化记录器

默认情况下,记录器采用层级结构,通过 . 来区分不同的层级。比如 有个名叫 foo 的记录器 则 foo.afoo.b 都是 foo 的子级记录器。当然,最开始的或者说最上层的记录器就是 root logger。如果 name=None,构建的是root logger。

可以直接用当前模块的名称当作记录器的名字 logging.getLogger(__name__)

子级记录器通常不需要单独设置日志级别以及 Handler,如果子级记录器没有单独设置,则它的行为会委托给父级。比如说,记录器foo的级别为INFO,而foo.afoo.b 都不设置日志级别。此时foo.afoo.b 会遵循foo 的级别设置,即只记录大于等于INFO级别的日志;而如果foo也没设置的话,就会找到根记录器root logger,root默认的级别为WARGING。

logger类的一些常用的方法

方法功能描述
Logger.setLevel()设置日志器(Logger)将会处理的日志消息级别
Logger.addHandler()添加一个handler对象
Logger.removeHandler()移除一个handler对象
Logger.addFilter()添加一个filter对象
Logger.removeFilter()移除一个filter对象
Logger.debug()设置DEBUG级别的日志记录
Logger.info()设置INFO级别的日志记录
Logger.warning()设置WARNING级别的日志记录
Logger.error()设置ERROR级别的日志记录
Logger.critical()设置CRITICAL级别的日志记录
Logger.exception()输出堆栈追踪信息
Logger.log()设置一个自定义的level参数来创建一个日志记录

logger 结合 后面要介绍的其他的三个组件可以实现以下的功能:

  • Logger需要通过handler将日志信息输出到目标位置,目标位置可以是sys.stdout和文件等(这与logging.basicConfig(**kwargs) 设置中不太一致)。

  • 一个Logger可以设置不同的Handler,而不同的Handler可以将日志输出到不同的位置(不同的日志文件),并且每个Handler都可以设置自己的filter从而实现日志过滤,保留实际项目中需要的日志。同时每个Handler也可以设置不同的Formatter,在每个Formatter实现同一条日志以不同的格式输出到不同的地方。

Handle

处理器;其可以控制记录的日志输出到什么地方(标准输出/文件/...),同时处理器也可以添加 过滤器(filter)和格式控制器(formatter)来控制输出的内容和输出的格式。

其具有几种常见的处理器:

  • logging.StreamHandler 标准流处理器,将消息发送到标准输出流、错误流 --> logging.StreamHandler(sys.stdout) # sys.stdout 表示的是指向控制台即标准输出;当我们在 Python 中打印对象调用 print obj 时候,事实上是调用了 sys.stdout.write(obj+'\n')。

  • print 将你需要的内容打印到了控制台,然后追加了一个换行符

  • logging.FileHandler 文件处理器,将消息发送到文件 --> logging.FileHandler(log_path)

  • logging.RotatingFileHandler 文件处理器,文件达到指定大小后,启用新文件存储日志

  • logging.TimedRotatingFileHandler 文件处理器,日志以特定的时间间隔轮换日志文件

handle 类的一些常用的方法

Handler.setLevel()设置处理器将会处理的日志消息的最低严重级别
Handler.setFormatter()为处理器设置一个格式对象
Handler.addFilter()为处理器添加一个过滤器对象
Handler.removeFilter()为处理器删除一个过滤器对象
logging.StramHandler()将日志消息发送到输出Stream,如std.out,std.err
logging.FilterHandler()将日志消息发送到磁盘文件,默认情况文件大小会无线增长
RotationFileHandler()将日志消息发送到磁盘文件,支持日志文件按大小切割
TimeRotatingFileHandler()将日志消息发送到磁盘文件,并支持日志文件按时间切割
logging.handers.HTTPHandler()将日志消息通过GET或POST的方式发送给一个HTTP服务器
logging.handlers.SMTPHandler()将日志消息发送email地址

Filter

filter组件用来过滤 logger 对象,一个 filter 可以直接添加到 logger对象上,也可以添加到 handler 对象上,而如果在logger和handler中都设置了filter,则日志是先通过logger的filter,再通过handler的filter。由于所有的信息都可以经过filter,所以filter不仅可以过滤信息,还可以增加信息。

Filter 类的实例化对象可以通过 logging.Filter(name) 来创建,其中name 为 记录器的名字,如果没有创建过该名字的记录器,就不会输出任何日志:

filter = logging.Filter("foo.a")

基本过滤器类只允许低于指定的日志记录器层级结构中低于特定层级的事件,例如 这个用 foo.a 初始化的过滤器,则foo.a.b;foo.a.c 等日志记录器记录的日志都可以通过过滤器,而foo.c; a.foo 等就不能通过。如果name为空字符串,则所有的日志都能通过。

Filter 类 有 三个方法 :

  • addFilter(filter) : 为 logger(logger..addFilter(filter)) 或者 handler(handler..addFilter(filter)) 增加过滤器

  • removeFilter(filter) : 为 logger 或者 handler 删除一个过滤器

  • filter(record) : 表示是否要记录指定的记录?返回零表示否,非零表示是。一般自定义Filter需要继承Filter基类,并重写filter方法

Formatter

格式化日志的输出;实例化:formatter = logging.Formatter(fmt=None,datefmt=None); 如果不指明 fmt,将默认使用 ‘%(message)s’ ,如果不指明 datefmt,将默认使用 ISO8601 日期格式。

其中 fmt 参数 有以下选项:

%(name)sLogger的名字
%(levelno)s数字形式的日志级别
%(levelname)s文本形式的日志级别;如果是logger.debug则它是DEBUG,如果是logger.error则它是ERROR
%(pathname)s调用日志输出函数的模块的完整路径名,可能没有
%(filename)s调用日志输出函数的模块的文件名
%(module)s调用日志输出函数的模块名
%(funcName)s调用日志输出函数的函数名
%(lineno)d调用日志输出函数的语句所在的代码行
%(created)f当前时间,用UNIX标准的表示时间的浮 点数表示
%(relativeCreated)d输出日志信息时的,自Logger创建以 来的毫秒数
%(asctime)s字符串形式的当前时间。默认格式是 “2003-07-08 16:49:45,896”。逗号后面的是毫秒
%(thread)d线程ID。可能没有
%(threadName)s线程名。可能没有
%(process)d进程ID。可能没有
%(message)s用户输出的消息; 假如有logger.warning("NO Good"),则在%(message)s位置上是字符串NO Good

例如:

formatter = logging.Formatter('%(asctime)s %(levelname)-8s: %(message)s')# -表示右对齐 8表示取8位handler.formatter = formatter

datefmt 参数 有以下选项:

参数含义
%y两位数的年份表示(00-99)
%Y四位数的年份表示(000-9999)
%m月份(01-12)
%d月内中的一天(0-31)
%H24小时制小时数(0-23)
%I12小时制小时数(01-12)
%M分钟数(00=59)
%S 秒(00-59)

例如:

formatter = logging.Formatter('%(asctime)s %(levelname)-8s: %(message)s')# -表示右对齐 8表示取8位handler.formatter = formatter

datefmt 参数 有以下选项:

参数含义
%y两位数的年份表示(00-99)
%Y四位数的年份表示(000-9999)
%m月份(01-12)
%d月内中的一天(0-31)
%H24小时制小时数(0-23)
%I12小时制小时数(01-12)
%M分钟数(00=59)
%S 秒(00-59)

例子:

formatter = logging.Formatter("%(asctime)s %(levelname)s %(message)s","%Y%m%d-%H:%M:%S")handler.formatter = formatter

logging 的配置

  • conf 形式的配置

在 loguser.conf 中 写入相关的信息

[loggers]keys=root,fileLogger,rotatingFileLogger[handlers]keys=consoleHandler,fileHandler,rotatingFileHandler[formatters]keys=simpleFormatter[logger_root]level=INFOhandlers=consoleHandler[logger_fileLogger]level=INFOhandlers=fileHandlerqualname=fileLoggerpropagate=0[logger_rotatingFileLogger]level=INFOhandlers=consoleHandler,rotatingFileHandlerqualname=rotatingFileLoggerpropagate=0[handler_consoleHandler]class=StreamHandlerlevel=INFOformatter=simpleFormatterargs=(sys.stdout,)[handler_fileHandler]class=FileHandlerlevel=INFOformatter=simpleFormatterargs=("logs/fileHandler_test.log", "a")[handler_rotatingFileHandler]class=handlers.RotatingFileHandlerlevel=WARNINGformatter=simpleFormatterargs=("logs/rotatingFileHandler.log", "a", 10*1024*1024, 50)[formatter_simpleFormatter]format=%(asctime)s - %(module)s - %(levelname)s -%(thread)d : %(message)sdatefmt=%Y-%m-%d %H:%M:%S
  • 在使用logger时,直接导入配置文件即可

from logging import configwith open('./loguser.conf', 'r', encoding='utf-8') as f:## 加载配置    config.fileConfig(f)    ## 创建同名Logger,其按照配置文件的handle,formatter,filter方法初始化    logger = logging.getLogger(name="fileLogger")
  • yaml 形式配置文件

在 loguser.yaml文件 中 配置相关信息

version: 1disable_existing_loggers: False# formatters配置了日志输出时的样式# formatters定义了一组formatID,有不同的格式;formatters:  brief:      format: "%(asctime)s - %(message)s"  simple:      format: "%(asctime)s - [%(name)s] - [%(levelname)s] :%(levelno)s: %(message)s"      datefmt: '%F %T'# handlers配置了需要处理的日志信息,logging模块的handler只有streamhandler和filehandlerhandlers:  console:      class : logging.StreamHandler      formatter: brief      level   : DEBUG      stream  : ext://sys.stdout  info_file_handler:      class : logging.FileHandler      formatter: simple      level: ERROR      filename: ./logs/debug_test.log  error_file_handler:    class: logging.handlers.RotatingFileHandler    level: ERROR    formatter: simple    filename: ./logs/errors.log    maxBytes: 10485760 # 10MB #1024*1024*10    backupCount: 50    encoding: utf8loggers:#fileLogger, 就是在代码中通过logger = logging.getLogger("fileLogger")来获得该类型的logger  my_testyaml:      level: DEBUG      handlers: [console, info_file_handler,error_file_handler]# root为默认情况下的输出配置, 当logging.getLogger("fileLoggername")里面的fileLoggername没有传值的时候,# 就是用的这个默认的root,如logging.getLogger(__name__)或logging.getLogger()root:    level: DEBUG    handlers: [console]

同样的可以通过导入 yaml 文件加载配置

with open('./loguser.yaml', 'r', encoding='utf-8') as f:        yaml_config = yaml.load(stream=f, Loader=yaml.FullLoader)        config.dictConfig(config=yaml_config)    root = logging.getLogger()    # 子记录器的名字与配置文件中loggers字段内的保持一致    # loggers:    #   my_testyaml:    #       level: DEBUG    #       handlers: [console, info_file_handler,error_file_handler]    my_testyaml = logging.getLogger("my_testyaml")

logging 和 print 的区别

看起来logging要比print复杂多了,那么为什么推荐在项目中使用 logging 记录日志而不是使用print 输出程序信息呢。

相比与print logging 具有以下优点:

  • 可以通过设置不同的日志等级,在 release 版本中只输出重要信息,而不必显示大量的调试信息;

  • print 将所有信息都输出到标准输出中,严重影响开发者从标准输出中查看其它数据;logging 则可以由开发者决定将信息输出到什么地方,以及怎么输出;

  • 和 print 相比,logging 是线程安全的。(python 3中 print 也是线程安全的了,而python 2中的print不是)(线程安全是指在多线程时程序不会运行混乱;而python 2 中的print 分两步打印信息,第一打印字符串,第二打印换行符,如果在这中间发生线程切换就会产生输出混乱。这就是为什么python2的print不是原子操作,也就是说其不是线程安全的)印信息,第一打印字符串,第二打印换行符,如果在这中间发生线程切换就会产生输出混乱。这就是为什么python2的print不是原子操作,也就是说其不是线程安全的)

感谢各位的阅读,以上就是“Python内置logging怎么使用”的内容了,经过本文的学习后,相信大家对Python内置logging怎么使用这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是编程网,小编将为大家推送更多相关知识点的文章,欢迎关注!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Python内置logging怎么使用

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Python内置logging怎么使用

这篇文章主要讲解了“Python内置logging怎么使用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python内置logging怎么使用”吧!logging 的主要作用提供日志记录的接
2023-07-02

logging怎么在Python中使用

本篇文章为大家展示了logging怎么在Python中使用,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。logid保存与传递传统做法就是讲 logid 保存在 threading.local 里面,
2023-06-14

Python中的logging模块怎么使用

这篇文章主要介绍“Python中的logging模块怎么使用”,在日常操作中,相信很多人在Python中的logging模块怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Python中的logging
2023-07-06

Python日志模块logging怎么使用

这篇“Python日志模块logging怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“Python日志模块loggi
2023-06-30

怎么使用Python内置库collections

这篇文章主要讲解了“怎么使用Python内置库collections”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用Python内置库collections”吧!Python中有很多好
2023-06-02

python logging简单使用

#coding: UTF-8'''Created on 2014年1月6日@author: mingliu'''import logging#导入mylog = logging.getLogger('mylogger')#申请一个名字oth
2023-01-31

python内置库wsgiref怎么使用

这篇文章主要介绍python内置库wsgiref怎么使用,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!WSGI基本原理1. WSGI处理过程浏览器到WSGI Server:浏览器发送的请求会先到WSGI Server
2023-06-15

怎么使用Python内置函数

这篇文章主要介绍“怎么使用Python内置函数”,在日常操作中,相信很多人在怎么使用Python内置函数问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”怎么使用Python内置函数”的疑惑有所帮助!接下来,请跟
2023-06-01

Python中内置的日志模块logging用法详解

logging模块简介 Python的logging模块提供了通用的日志系统,可以方便第三方模块或者是应用使用。这个模块提供不同的日志级别,并可以采用不同的方式记录日志,比如文件,HTTP GET/POST,SMTP,Socket等,甚至可
2022-06-04

怎么使用Python内置数据库

这篇文章主要讲解了“怎么使用Python内置数据库”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么使用Python内置数据库”吧!导入和使用这里我们说“内置”的意思就是,你甚至不需要运行
2023-06-16

python logging日志模块怎么用

这篇文章主要讲解了“python logging日志模块怎么用”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“python logging日志模块怎么用”吧!1.日志简介说到日志,无论是写框架
2023-06-29

python之logging模块使用

#!/usr/bin/env python# encoding: utf-8import logging#定义handler的输出格式formatter=logging.Formatter('%(asctime)s--%(name)s--%
2023-01-31

Python常用内置函数怎么使用

这篇文章主要介绍“Python常用内置函数怎么使用”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Python常用内置函数怎么使用”文章能帮助大家解决问题。一、abs()abs() 用于返回一个数的绝
2023-07-05

怎么在python中配置Logging处理器

怎么在python中配置Logging处理器?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。Python主要用来做什么Python主要应用于:1、Web开发;2、数据科学研究;3
2023-06-14

python中使用logging的好处是什么

本篇内容主要讲解“python中使用logging的好处是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python中使用logging的好处是什么”吧!说明1、允许指定记录信息的级别,包括
2023-06-20

python中的内置函数怎么使用

Python中的内置函数是可直接使用的函数,不需要先导入任何模块。你可以直接在代码中调用这些函数来完成特定的操作。以下是一些常用的内置函数及其用法示例:1. `print()`:用于打印输出内容到控制台。示例:`print("Hello,
2023-09-07

python爬虫怎么使用内置的scrapy内置下载文件

这篇文章主要介绍python爬虫怎么使用内置的scrapy内置下载文件,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!python是什么意思Python是一种跨平台的、具有解释性、编译性、互动性和面向对象的脚本语言,其
2023-06-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录