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. 使用纯注解方式实现账户的CRUD

    1 需求和技术要求 1.1 需求 实现账户的CRUD. 1.2 技术要求 使用Spring的IOC实现对象的管理. 使用QueryRunner作为持久层的解决方案. 使用C3p0作为数据源. 2 搭建 ...

  2. keep-alive前进没有刷新

    https://segmentfault.com/a/1190000012083511

  3. BZOJ 4423: [AMPPZ2013]Bytehattan 平面图转对偶图 + 并查集

    Description 比特哈顿镇有n*n个格点,形成了一个网格图.一开始整张图是完整的.有k次操作,每次会删掉图中的一条边(u,v),你需要回答在删除这条边之后u和v是否仍然连通. Input 第一 ...

  4. Tensorflow在win10下的安装(CPU版本)

    环境:win10,64位 1.卸载python3.7,安装python3.6 由于之前已经安装了python,到tensorflow网站查看tensorflow的支持环境,https://tensor ...

  5. jQuery_完成表格的隔行换色

    表格的颜色一样不利于区分,而利用jQuery则可以很方便的进行表格的隔行换色操作,原表如下: 这样看着很不方便,但是隔行换色之后非常便捷清楚. 代码如下: <!DOCTYPE html> ...

  6. shell java应用启动脚本(app.sh)

    #!/bin/sh # java服务中需要的jar文件或classpath路径,如业务程序.第三方jar文件log4j等 ShellAbsPath=$(cd "$(dirname " ...

  7. 综合KPI报表历史明细数据查询

    一.综合计划部KPI明细数据查询--xigu用户要求:需显示第三季度,即789三个月的明细数据解决方法:1.查看SSISC:\Users\Administrator\Documents\Visual ...

  8. 大数据笔记(二十三)——Scala语言基础

    一.Scala简介:一种多范式的编程语言 (*)面向对象 (*)函数式编程:Scala的最大特点 (*)基于JVM 二.Scala的运行环境 (1)命令行:REPL 进入: scala 退出::qui ...

  9. RestFul的无状态规则详解

    无状态原则 Statelessness:无状态原则是RESTful架构设计中一个非常重要的原则,无状态是相对于有状态而言的.在理解什么是无状态的交互请求之前,首先我们需要了解什么是有状态,并对两者进行 ...

  10. http://www.malware-traffic-analysis.net/2018/index.html

    http://www.malware-traffic-analysis.net/2018/index.html