LOG

  • logging 模块提供模块级别的函数记录日志
  • 包括四大组件

1. 日志相关概念

1.1 日志的级别 level

  1. DEBUG
  2. INFO
  3. NOTICE
  4. WARNING
  5. ERROR
  6. CRITICAL
  7. ALERT
  8. EMERGENCY
  • 用户可以关注自己所需的程序信息

1.2 LOG 的作用

  • 调试
  • 了解软件的运行情况
  • 分析定位问题

1.3 日志信息

  • time
  • level
  • 地点
  • 内容

1.4 成熟的第三方日志

  • logging
  • log4j
  • log4php

1.5 注意

  • 不要频繁地进行 IO 操作

2. Logging 模块

2.1 日志级别

  • DEBUG
  • INFO
  • WARNING
  • ERROR
  • CRITICAL

2.2 使用方法

  1. 直接使用 logging,因为 logging 封装了其他组件

  2. 用 loging 四大组件直接定制

2.3 注意事项

  • 初始化或写日志实例需要指定级别
  • 级别可自定义
  • 只有当级别等于或高于指定级别才被记录

2.4 logging 模块级别的日志

2.4.1 logging 的几个函数

函数 释义
logging.debug(msg, *args, **kwargs) 创建一条严重级别为 DEBUG 的日志记录
logging.info(msg, *args, **kwargs) 创建一条严重级别为 INFO 的日志记录
logging.warning(msg, *args, **kwargs) 创建一条严重级别为 WARNING 的日志记录
logging.error(msg, *args, **kwargs) 创建一条严重级别为 ERROR 的日志记录
logging.critical(msg, *args, **kwargs) 创建一条严重级别为 CRITICAL 的日志记录
logging.log(level, *args, **kwargs) 创建一条严重级别为 level 的日志记录
logging.basicConfig(**kwargs) root logger 进行一次性配置
  • logging.basicConfig(**kwargs)

    • 只在第一次调用的时候起作用
    • 不配置 logger 则使用默认值
      • 输出:sys.stderr
      • 级别:WARNING
      • 格式:level:log_name:content

2.4 2 举例

  • format 参数
参数 用法 释义
asctime %(asctime)s 日志事件发生的时间——人类可读时间
如:2019-12-24 17:00:12,765
created %(created)f 日志事件发生的时间——时间戳
与调用 time.time() 函数返回的值相同
relativeCreated %(relativeCreated)d 日志事件发生的时间相对于
logging 模块加载时间的相对毫秒数
msecs %(msecs)d 日志事件发生事件的毫秒部分
levelname %(levelname)s 该日志记录的文字形式的日志级别
'DEBUG', 'INFO', 'WARNING', 'ERROR', 'CRITICAL'
levelno %(levelno)s 该日志记录的数字形式的日志级别 (10, 20, 30, 40, 50)
name %(name)s 所使用的日志器名称,默认是'root'
因为默认使用的是 rootLogger
message %(message)s 日志记录的文本内容,通过 msg % args计算得到的
pathname %(pathname)s 调用日志记录函数的源码文件的全路径
filename %(filename)s pathname 的文件名部分,包含文件后缀
module %(module)s filename 的名称部分,不包含后缀
lineno %(lineno)d 调用日志记录函数的源代码所在的行号
funcName %(funcName)s 调用日志记录函数的函数名
process %(process)d 进程 ID
processName %(processName)s 进程名称,Python 3.1 新增
thread %(thread)d 线程 ID
threadName %(thread)s 线程名称

2.5 logging 模块的处理流程

  • 四大组件
组件 作用
日志器 Logger 产生日志的一个接口
处理器 Handler 把产生的日志发送到相应的目的地
过滤器 Filter 更精细的控制那些日志输出
格式器 Formatter 对输出信息进行格式化

2.5.1 Logger

  • 产生一个日志
函数 释义
Logger.setLevel() 设置日志器将会处理的日志消息的最低严重级别
Logger.addHandler() 和 Logger.removeHandler() 为该 logger 对象添加 和 移除一个 handler 对象
Logger.addFilter() 和 Logger.removeFilter() 为该 logger 对象添加 和 移除一个 filter 对象
Logger.debug 产生一条 debug 级别的日志
info, error 等同理
Logger.exception() 创建类似于 Logger.error 的日志消息
Logger.log() 获取一个明确的日志 level 参数类创建一个日志记录
  • 如何得到一个 logger 对象
  1. 实例化
  2. logging.getLogger()

2.5.2 Handler

  • 把 log 发送到制定位置
  • 方法
    • setLevel
    • setFormat
    • addFilter, removeFilter
  • 不需要直接使用,Handler 是基类
方法 释义
logging.StreamHandler 将日志消息发送到输出到 Stream
如 std.out, std.err 或任何 file-like 对象
logging.FileHandler 将日志消息发送到磁盘文件
默认情况下文件大小会无限增长
logging.handlers.RotatingFileHandler 将日志消息发送到磁盘文件,并支持日志文件按大小切割
logging.hanlders.TimedRotatingFileHandler 将日志消息发送到磁盘文件,并支持日志文件按时间切割
logging.handlers.HTTPHandler 将日志消息以 GET 或 POST 的方式发送给一个 HTTP 服务器
logging.handlers.SMTPHandler 将日志消息发送给一个指定的 email 地址
logging.NullHandler 该 Handler 实例会忽略 error messages
通常被想使用 logging 的 library 开发者使用来避免
'No handlers could be found for logger XXX' 信息的出现

2.5.3 Filter 类

  • 可以被 Handler 和 Logger 使用
  • 控制传递过来的信息的具体内容

2.5.4 Format 类

  • 直接实例化
  • 可以继承 Format 添加特殊内容
  • 三个参数
参数 释义
fmt 指定消息格式化字符串,如果不指定该参数则默认使用 message 的原始值
datefmt 指定日期格式字符串,如果不指定该参数则默认使用 "%Y-%m-%d %H:%M:%S"
style Python 3.2 时新增的参数,可取值为 '%', '{' 和 '$',如果不指定该参数则默认使用 '%'

[Python3] 042 日志的更多相关文章

  1. Python3自定义日志类教程

    一.说明 Python3的logging功能是比较丰富的支持不同层次的日志输出,但或是我们想在日志前输出时间.或是我们想要将日志输入到文件,我们还是想要自定义日志类. 之前自己也尝试写过但感觉文档太乱 ...

  2. python3 log 日志记录

    在调试的过程中,很多地方需要用到日志 如下 import logging LOG_FORMAT = "%(asctime)s - %(levelname)s - %(message)s&qu ...

  3. Python3自定义日志类 mylog

    #encoding=utf-8 import os, sysimport datetimeimport time class Mylog(object): # 根文件夹    root_dir = s ...

  4. python3 logging 日志记录模块

    #coding:utf-8 import logginglogging.basicConfig(filename='log1.log', format='%(asctime)s -%(name)s-% ...

  5. Python3的日志添加功能

    python日志添加功能,主要记录程序运行中的日志,统一收集并分析 一.日志的级别 debug(调试信息) info() warning(警告信息)error(错误信息) critical(致命信息) ...

  6. python3 日志重复打印logger

    在python2中正常的日志,单只直接使用python3,发现日志重复了,其实是handlers多添加的原因, python2代码 ---------------------------------- ...

  7. python全栈开发中级班全程笔记(第二模块、第四章)(常用模块导入)

    python全栈开发笔记第二模块 第四章 :常用模块(第二部分)     一.os 模块的 详解 1.os.getcwd()    :得到当前工作目录,即当前python解释器所在目录路径 impor ...

  8. sanic官方文档解析之logging和request Data

    1,sanic的logging: Sanic允许有做不同类型的日志(通过的日志,错误的日志),在基于Python3的日志API接口请求,你必须具备基本的Python3的日志知识,在你如果想创建一个新的 ...

  9. python3+selenium框架设计03-封装日志类

    首先我们先来实现日志的功能,日志可以使用python3自带logging模块,不会的可以百度一下相关文章,也可以看我另外一篇文章Python3学习笔记24-logging模块 在封装日志类前,我们需要 ...

随机推荐

  1. win10系统配置java环境及遇到问题的一些处理方法

    O1   java安装: 从java官网下载:https://www.java.com/zh_CN/ 安装教程:http://jingyan.baidu.com/article/03b2f78c137 ...

  2. POJ-2552-The Bottom of a Graph 强连通分量

    链接: https://vjudge.net/problem/POJ-2553 题意: We will use the following (standard) definitions from gr ...

  3. print的位置差异

    第一种,for循环和print是同级的,只有当for循环结束了才会print d=[]for i in range(1, 101): d.append(i)print d[6::7] 第二种,也就是p ...

  4. pandas Series和dataframe

    DataFrame是一个表格型数据结构,与Series不同的是,DataFrame可以含有一组或者有序的列,每列可以使不同的值的类型,它可以被看做成Series的字典.

  5. Linux基础教程 linux系统中的批量删除文件与空文件删除的命令介绍

    linux下面删除文件或者目录命令rm(remove): 兄弟连Linux培训 功能说明:删除文件或目录. 语 法:rm[-dfirv][--help][--version][文件或目录...] 补充 ...

  6. PHP基础-表达式介绍

    表达式是 PHP 最重要的基石.在PHP 编程 中,几乎所写的任何东西都是一个表达式.简单但却最精确的定义一个表达式的方式就是“任何有值的东西”. 最基本的表达式形式是常量和变量.当键入“$a = 5 ...

  7. C++ 值传递、指针传递、引用传递

    1.值传递 (1)形参是实参的拷贝(这句话说明形参和实参是两个实体),改变形参的值并不会影响外部实参的值. (2)从被调用函数的角度来说,值传递是单向的(实参->形参),参数的值只能传入,不能传 ...

  8. 极验验证码在php5.6.27下不显示

    PHP5.6需要改php.ini 去掉;always_populate_raw_post_data = -1的 :

  9. android存储路径问题

    关于存储路径问题,如果是想要存储在应用本身的路径下,如果该应用卸载的时候,对应文件随之卸载, 如果使用的是android level 8以上的版本,采用的是: getExternalFilesDir( ...

  10. linux cut sort wc sed>vi awk (文本处理)

    cut: 显示切割的行数据 -f: 选择显示的列 (1: 显示第一列; 1,3: 显示第一列.第三列; 1-3: 显示第一列到第三列) -s: 不显示没有分隔符的行 -d: 自定义分隔符(' '空格 ...