Python的log日志功能及设置方法

作者:DefaultTest 时间:2022-03-28 22:13:32 

引入:Python中有个logging模块可以完成相关信息的记录,在debug时用它往往事半功倍

一、日志级别(从低到高):

DEBUG :详细的信息,通常只出现在诊断问题上

INFO:确认一切按预期运行

WARNING:一个迹象表明,一些意想不到的事情发生了,或表明一些问题在不久的将来(例如。磁盘空间低”)。这个软件还能按预期工作。

ERROR:更严重的问题,软件没能执行一些功能

CRITICAL :一个严重的错误,这表明程序本身可能无法继续运行

注:这5个等级,也分别对应5种打日志的方法: debug 、info 、warning 、error 、critical。默认的是WARNING,当在WARNING或之上时才被跟踪。

二、日志输出:显示到控制台或保存到文件中,可以灵活选用


# 这里为了简便,同时处理:输出控制台和保存到文件中

import logging

# 第一步,创建一个logger
logger = logging.getLogger()
logger.setLevel(logging.INFO) # Log等级总开关

# 第二步,创建一个handler,用于写入日志文件
logfile = './log.txt'
fh = logging.FileHandler(logfile, mode='a') # open的打开模式这里可以进行参考
fh.setLevel(logging.DEBUG) # 输出到file的log等级的开关

# 第三步,再创建一个handler,用于输出到控制台
ch = logging.StreamHandler()
ch.setLevel(logging.WARNING)  # 输出到console的log等级的开关

# 第四步,定义handler的输出格式
formatter = logging.Formatter("%(asctime)s - %(filename)s[line:%(lineno)d] - %(levelname)s: %(message)s")
fh.setFormatter(formatter)
ch.setFormatter(formatter)

# 第五步,将logger添加到handler里面
logger.addHandler(fh)
logger.addHandler(ch)

# 日志
logger.debug('这是 logger debug message')
logger.info('这是 logger info message')
logger.warning('这是 logger warning message')
logger.error('这是 logger error message')
logger.critical('这是 logger critical message')

三、日志格式说明

logging.basicConfig函数中,可以指定日志的输出格式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

%(message)s: 打印日志信息

来源:https://blog.csdn.net/DefaultTest/article/details/81069860

标签:Python,log,日志
0
投稿

猜你喜欢

  • python 实现二维数组的索引、删除、拼接操作

    2021-03-01 10:28:08
  • swfupload上传使用代码说明ASP版

    2011-11-27 09:34:32
  • ASP经常用到的函数

    2009-07-06 13:00:00
  • python多线程使用方法实例详解

    2023-08-18 17:34:00
  • 对matplotlib改变colorbar位置和方向的方法详解

    2023-07-13 21:00:04
  • 关于ASP代码的加密

    2007-10-15 12:30:00
  • php中in_array函数用法探究

    2023-06-21 21:03:54
  • pytorch cnn 识别手写的字实现自建图片数据

    2023-04-18 02:39:22
  • Swoole webSocket消息服务系统代码设计详解

    2023-06-09 01:05:28
  • 用伪类:hover实现提示效果

    2008-05-29 12:59:00
  • 请给PNG8一个机会:对png8的误解

    2009-09-21 10:45:00
  • 浅谈ACCESS数据库升迁SQLSERVER注意事项

    2007-08-11 13:44:00
  • 基于Python实现天天酷跑功能

    2022-09-30 01:18:33
  • Python注释、分支结构、循环结构、伪“选择结构”用法实例分析

    2021-01-15 14:45:25
  • asp如何利用当前时间生成随机函数?

    2010-01-01 15:44:00
  • ASP运行出错:缺少对象: xmlDoc.documentElement错误解决方法

    2012-11-30 20:40:52
  • python获取全国最新省市区数据并存入表实例代码

    2021-10-19 14:16:23
  • python捕获警告的三种方法

    2021-10-17 09:45:25
  • python数组的复制与列表中的pop

    2021-07-10 12:05:24
  • python使用json.dumps输出中文问题

    2023-11-17 22:04:46
  • asp之家 网络编程 m.aspxhome.com