[Python3] 042 日志
目录
LOG
- logging 模块提供模块级别的函数记录日志
- 包括四大组件
1. 日志相关概念
1.1 日志的级别 level
- DEBUG
- INFO
- NOTICE
- WARNING
- ERROR
- CRITICAL
- ALERT
- 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 使用方法
直接使用 logging,因为 logging 封装了其他组件
用 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 对象
- 实例化
- 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 日志的更多相关文章
- Python3自定义日志类教程
一.说明 Python3的logging功能是比较丰富的支持不同层次的日志输出,但或是我们想在日志前输出时间.或是我们想要将日志输入到文件,我们还是想要自定义日志类. 之前自己也尝试写过但感觉文档太乱 ...
- python3 log 日志记录
在调试的过程中,很多地方需要用到日志 如下 import logging LOG_FORMAT = "%(asctime)s - %(levelname)s - %(message)s&qu ...
- Python3自定义日志类 mylog
#encoding=utf-8 import os, sysimport datetimeimport time class Mylog(object): # 根文件夹 root_dir = s ...
- python3 logging 日志记录模块
#coding:utf-8 import logginglogging.basicConfig(filename='log1.log', format='%(asctime)s -%(name)s-% ...
- Python3的日志添加功能
python日志添加功能,主要记录程序运行中的日志,统一收集并分析 一.日志的级别 debug(调试信息) info() warning(警告信息)error(错误信息) critical(致命信息) ...
- python3 日志重复打印logger
在python2中正常的日志,单只直接使用python3,发现日志重复了,其实是handlers多添加的原因, python2代码 ---------------------------------- ...
- python全栈开发中级班全程笔记(第二模块、第四章)(常用模块导入)
python全栈开发笔记第二模块 第四章 :常用模块(第二部分) 一.os 模块的 详解 1.os.getcwd() :得到当前工作目录,即当前python解释器所在目录路径 impor ...
- sanic官方文档解析之logging和request Data
1,sanic的logging: Sanic允许有做不同类型的日志(通过的日志,错误的日志),在基于Python3的日志API接口请求,你必须具备基本的Python3的日志知识,在你如果想创建一个新的 ...
- python3+selenium框架设计03-封装日志类
首先我们先来实现日志的功能,日志可以使用python3自带logging模块,不会的可以百度一下相关文章,也可以看我另外一篇文章Python3学习笔记24-logging模块 在封装日志类前,我们需要 ...
随机推荐
- DevExpress Windows 10 v19.1新版亮点:UWP控件新功能全面解析
行业领先的.NET界面控件DevExpress 日前正式发布v19.1版本,本站将以连载的形式介绍各版本新增内容.在本系列文章中将为大家介绍DevExpress WPF v19.1中新增的一些控件及部 ...
- ESP8266 SPI通信
设备与设备之间的通信往往都伴随着总线的使用,而用得比较多的就当属于SPI总线和I2C总线,而恰巧NodeMcu也支持这两种总线通信 1. SPI总线——SPI类库的使用 SPI是串行外设接口(Seri ...
- python 脚本制作
U盘拷贝 当U盘插入主机时 被系统识别挂载后 通过python代码自动的去读取U盘中的资料并且进行拷贝 寄存在U盘上的 把硬盘上的资料进行读取并移动到U盘里 有点像 繁殖性 传输性 破坏性 破坏系统或 ...
- Python代码2转3、3转2的方法
众所周知,Python2和Python3不兼容. 那么,假如遇到了超大的工作量,我们是不是需要一行一行地手动去改呢? 当然不是. (一)2转3 Python3.7(顺便提一句,现在装3.7发现好像安装 ...
- codevs 5935 小球 x
题目描述 Description 许多的小球一个一个的从一棵满二叉树上掉下来组成FBT(Full Binary Tree,满二叉树),每一时间,一个正在下降的球第一个访问的是非叶子节点.然后继续下降时 ...
- linux socket设置阻塞与非阻塞
非阻塞IO 和阻塞IO: 在网络编程中对于一个网络句柄会遇到阻塞IO 和非阻塞IO 的概念, 这里对于这两种socket 先做一下说明: 基本概念: 阻塞IO:: socket 的阻塞模式 ...
- pycharm如何添加固定代码块
1. file -- settings -- 搜索框输入live,找到 Live Templates 2. 选择你要添加到哪个语言中去,打开python组,并点击右上角 “+”,选择 1.Live T ...
- (53)LINUX应用编程和网络编程之八Linux网络基础
3.8.1.网络通信概述 3.8.1.1.从进程间通信说起:网络域套接字socket,网络通信其实就是位于网络中不同主机上面的2个进程之间的通信. 3.8.1.2.网络通信的层次 (1)硬件部分:网卡 ...
- shell变量与运算
shell变量与运算 @(0003 shell编程) 变量存在于内存中.假设变量str,设置或修改变量属性时,不带$号,只有引用变量的值时才使用$号.也就是说在内存中,标记变量的变量名称是str,而不 ...
- Oracle升级11.2.0.3-11.2.0.4(Windows)
背景:解决11.2.0.3带来的ora-08103错误,将数据库seinescm升级到11.2.0.4版本方法:另辟路劲安装11.2.0.4版本数据库软件,再对现有的数据库进行升级步骤:1. 检 ...