文章目录

  • 日志级别
  • basicConfig关键字参数
  • 有用的format格式
  • 简单日志打印:
  • 只输出到文件不在ternimal打印
  • 既输出到文件,又打印到terminal
  • 日常使用

日志级别

级别 何时使用
DEBUG 详细信息,典型地调试问题时会感兴趣。
INFO 证明事情按预期工作。
WARNING 表明发生了一些意外,或者不久的将来会发生问题(如‘磁盘满了’)。软件还是在正常工作。
ERROR 由于更严重的问题,软件已不能执行一些功能了。
CRITICAL 严重错误,表明软件已不能继续运行了。

简单配置使用

# -*- coding:utf-8 -*-
import logging# 通过下面的方式进行简单配置输出方式与日志级别
logging.basicConfig(filename='logger.log', level=logging.INFO)logging.debug('debug message')
logging.info('info message')
logging.warn('warn message')
logging.error('error message')
logging.critical('critical message')

输出:
标准输出(屏幕)未显示任何信息,发现当前工作目录下生成了logger.log,内容如下:

INFO:root:info message
WARNING:root:warn message
ERROR:root:error message
CRITICAL:root:critical message

因为通过level=logging.INFO设置日志级别为INFO,所以INFO级别及以上的日志信息均输出出来了。

默认情况下,logging模块将日志打印到屏幕上(stdout),日志级别为WARNING(即只有日志级别高于WARNING的日志信息才会输出),日志格式如下图所示:

basicConfig关键字参数

关键字 描述
filename 创建一个FileHandler,使用指定的文件名,而不是使用StreamHandler。
filemode 如果指明了文件名,指明打开文件的模式(如果没有指明filemode,默认为’a’)。
format handler使用指明的格式化字符串。
datefmt 使用指明的日期/时间格式。
level 指明根logger的级别。
stream 使用指明的流来初始化StreamHandler。该参数与’filename’不兼容,如果两个都有,'stream’被忽略。

有用的format格式

格式 描述
%(levelno)s 打印日志级别的数值
%(levelname)s 打印日志级别名称
%(pathname)s 打印当前执行程序的路径
%(filename)s 打印当前执行程序名称
%(funcName)s 打印日志的当前函数
%(lineno)d 打印日志的当前行号
%(asctime)s 打印日志的时间
%(thread)d 打印线程id
%(threadName)s 打印线程名称
%(process)d 打印进程ID
%(message)s 打印日志信息

简单日志打印:

filename = time.strftime('%Y-%m-%d', time.localtime(time.time()))logging.basicConfig(level=logging.DEBUG,format='%(asctime)s \tFile \"%(filename)s\"[line:%(lineno)d] %(levelname)s %(message)s',# datefmt='%a, %d %b %Y %H:%M:%S',filename="./log/" + filename + ".log",filemode='a')logging.debug('debug message')
logging.info('info message')
logging.warn('warn message')
logging.error('error message')
logging.critical('critical message')

logging.basicConfig()函数中可通过具体参数来更改logging模块默认行为,可用参数有

  • filename:用指定的文件名创建FiledHandler(后边会具体讲解handler的概念),这样日志会被存储在指定的文件中。
  • filemode:文件打开方式,在指定了filename时使用这个参数,默认值为“a”还可指定为“w”。
  • format:指定handler使用的日志显示格式。
  • datefmt:指定日期时间格式。
  • level:设置rootlogger; 默认的日志级别设置为WARNING(日志级别等级CRITICAL > ERROR > WARNING > INFO > DEBUG > NOTSET)
  • stream:用指定的stream创建StreamHandler。可以指定输出到sys.stderr,sys.stdout或者文件,默认为sys.stderr。若同时列出了filename和stream两个参数,则stream参数会被忽略。

format参数中可能用到的格式化串:

%(name)s Logger的名字
%(levelno)s 数字形式的日志级别
%(levelname)s 文本形式的日志级别
%(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用户输出的消息

logging库提供了两个可以用于日志滚动的class(可以参考https://docs.python.org/2/library/logging.handlers.html,一个是RotatingFileHandler,它主要是根据日志文件的大小进行滚动,另一个是TimeRotatingFileHandler,它主要是根据时间进行滚动。在实际应用中,我们通常根据时间进行滚动,因此,本文中主要介绍TimeRotaingFileHandler的使用方法(RotatingFileHandler一样)。

只输出到文件不在ternimal打印

import logging,re
from logging.handlers import TimedRotatingFileHandler
from logging.handlers import RotatingFileHandlerfilename = time.strftime('%Y-%m-%d', time.localtime(time.time()))def log_init(message):log_fmt = '%(asctime)s\tFile \"%(filename)s\",line %(lineno)s\t%(levelname)s: %(message)s'formatter = logging.Formatter(log_fmt)log_file_handler = TimedRotatingFileHandler(filename="./log/" + filename + ".log", when="D", interval=1, backupCount=30)log_file_handler.suffix = "%Y-%m-%d.log"log_file_handler.extMatch = re.compile(r"^\d{4}-\d{2}-\d{2}.log$")log_file_handler.setFormatter(formatter)log_file_handler.setLevel(logging.DEBUG)log = logging.getLogger()log.addHandler(log_file_handler)'''程序运行'''log.info(message)#removeHandler 要放在程序运用打印日志的后面log.removeHandler(log_file_handler)#  用pop方法把logger.handlers列表中的handler移除,注意如果你add了多个handler,这里需多次pop,或者可以直接为handlers列表赋空值# log.handlers.pop()# log.handler = []log_init('1234')

结果是每天生成一个日志文件,保留最近30天的日志文件。

when:是一个字符串,用于描述滚动周期的基本单位,字符串的值及意义如下:

  • “S”: Seconds
  • “M”: Minutes
  • “H”: Hours
  • “D”: Days
  • “W”: Week day (0=Monday)
  • “midnight”: Roll over at midnight
  • interval: 滚动周期,单位有when指定,比如:when=’D’,interval=1,表示每天产生一个日志文件;
  • backupCount: 表示日志文件的保留个数;

删除日志文件设置:

log_file_handler.suffix = “%Y-%m-%d_%H-%M.log”
log_file_handler.extMatch = re.compile(r”^\d{4}-\d{2}-\d{2}_\d{2}-\d{2}.log$”)

suffix和extMatch的格式要相对应,Year-4位,m-2位 以此类推

既输出到文件,又打印到terminal

import loggingfilename = time.strftime('%Y-%m-%d', time.localtime(time.time()))def initLogging(message):logging.basicConfig(level    = logging.DEBUG,format   = '%(asctime)s\tFile \"%(filename)s\",line %(lineno)s\t%(levelname)s: %(message)s',# datefmt  = '%a, %d %b %Y %H:%M:%S',filename = "./log/" + filename + ".log",filemode = 'w')#添加StreamHandler在控制台也打印出来console = logging.StreamHandler()console.setLevel(logging.INFO)formatter = logging.Formatter('LINE %(lineno)-4d : %(levelname)-8s %(message)s')console.setFormatter(formatter)logging.getLogger('').addHandler(console)logging.info(message)initLogging('123')

通过logging.StreamHandler()函数来打印到terminal

新建一个文件:myLog.py

# encoding:utf-8
import sys
import logging
import time  def writeLog(message):logger = logging.getLogger()# streamhandler = logging.StreamHandler()filename = time.strftime('%Y-%m-%d', time.localtime(time.time()))handler = logging.FileHandler("./log/" + filename + ".log")logger.addHandler(handler)logger.setLevel(logging.INFO )logger.info(datetime.datetime.now().strftime('%Y-%m-%d %H:%M:%S')+':'+message)#  添加下面一句,在记录日志之后移除句柄logger.removeHandler(handler)if __name__ == '__main__':  writeLog("hello")

然后直接在其他文件引用import myLog ,对于要写入的消息 用 myLog.writeLog('insert bad ') 写入 insert bad 的消息

日常使用

# -*- coding:utf-8 -*-
import os,sys, time
import json,requests
import logging,logging.handlersdef get_logger(log_name='',date_str=None):local_path="./logs/"if not os.path.exists(local_path):# os.mkdir(local_path)# 只能创建一级目录os.makedirs(local_path)  # 可以创建多级目录if date_str==None:date_str = time.strftime('%Y-%m-%d', time.localtime(time.time()))logfile = local_path + date_str + log_name + ".log"# hander = logging.handlers.RotatingFileHandler(logfile,encoding='utf-8')# 日志文件切割hander = logging.handlers.TimedRotatingFileHandler(filename=logfile, when="D", interval=1, backupCount=60)hander.suffix = hander.suffix + ".log"# print(hander.suffix)formatter = logging.Formatter('%(asctime)s [%(filename)s:%(lineno)s][%(levelname)s] %(message)s')hander.setFormatter(formatter)logger = logging.getLogger(logfile)## 每次被调用后,清空已经存在handler,不然日志会打印多遍logger.handlers.clear()logger.addHandler(hander)logger.setLevel(logging.INFO)return loggerlogger=get_logger(log_name='_test',date_str=None)
logger.info('test')

参考:https://www.jianshu.com/p/feb86c06c4f4
https://wenku.baidu.com/view/0601b8d2b90d4a7302768e9951e79b8969026845.html

[102]python写日志相关推荐

  1. python写日志文件_Python logging日志模块 配置文件方式

    在一些微服务或web服务中我们难免需要日志功能,用来记录一些用户的登录记录,操作记录,以及一些程序的崩溃定位,执行访问定位等等; Python内置 非常强大的日志模块 ==> logging 今 ...

  2. 够用的 Python 写日志的知识——标准日志模块logging简介

    前一段工作的时候用到了python写后台系统,需要把一些系统的行为记录下来.本着不要去重复发明轮子的精神,就去搜索了一下python的系统库本身是否有写日志的模块.果然有.python语言作为一门接口 ...

  3. python写日志到文件_Python日志文件没有正确地写入日志消息,只有格式

    我一夜之间运行了一个Python脚本,发现日志文件只是我指定的消息格式的重复行,而不是实际的消息.在 main 模块中,我创建了如下记录器: from datetime import datetime ...

  4. python写日志到文件_python 通过logging写入日志到文件和控制台的实例

    如下所示: import logging # 创建一个logger logger = logging.getLogger('mylogger') logger.setLevel(logging.DEB ...

  5. Python写日志文件

     日志文件是记录程序操作及事件的记录文件或记录文件的集合.一般由程序开发人员编写,开发.运维人员共同使用,开发人员可以通过日志调试程序,运维人员通过日志检查程序近期是否正常运行,如果出现异常,则可通过 ...

  6. python多线程怎么写日志_Python日志记录在多进程下的使用

    1. 问题描述 项目中,使用RotatingFileHandler根据日志文件大小来切分日志.设置文件的MaxBytes为1GB, backupCount大小为5. 经查看,发现日志文件的大小均小于1 ...

  7. 『R语言Python』使用logging、log4r写日志

    在开发的过程中,我们常会碰到又长又臭的脚本代码,当脚本出现bug需要进行排查时,总会使我们焦头烂额,而日志能很好的帮助我们记录脚本运行过程中所产生的信息,还能帮助我们定位异常,下面总结下我在R和pyt ...

  8. python logging模块-写日志、log回滚

    python包/模块,专栏总目录: 1.python自定义模块 2.python模块调用顺序 3.python logging模块 4.python定义跨模块的全局变量 1.logging模块简介 l ...

  9. python 网络接口 开发_Python自动化学习笔记(八)——接口开发、发送网络请求、发送邮件、写日志...

    1.接口开发(flask模块) Python自动化学习笔记(七)接口开发部分的内容补充 1.1参数为json格式: flask.request.is_json #判断参数是否是json格式 flask ...

最新文章

  1. ISME:菌根真菌菌丝分泌物中的果糖作为信号激发解磷细菌活化植酸
  2. ajax formdata 获取表单数据,node处理表单文件,获取formdata的数据
  3. 深度学习在医学影像的三大类项目应用
  4. 初步认识Volatile-MESI优化带来的可见性问题
  5. 双链表嵌套的简单学生信息管理系统
  6. Windows下利用C++实现Git自动克隆项目
  7. pyplot设置刻度字体大小以及标签字体大小
  8. 获取元素的位置信息的方法
  9. PHP+Swoole实现的网页即时聊天通讯工具:PHPWebIM
  10. 大学毕业必须知道的东西:三方协议、报到证(派遣证)、干部身份
  11. deactive(Deactive breakpoint)
  12. Unity 3D官方教程——2D Roguelike学习记录
  13. 宝塔linux怎么安装asp网站,宝塔面板创建网站:宝塔linux面板添加网站详细教程...
  14. MATLAB APP设计
  15. Windows认证机制详解(借物表在文章末尾)
  16. 再见,斗鱼!再见,虎牙!
  17. tp5 限制访问频次
  18. 文件批量重命名工具.exe
  19. python中filepath路径怎么写_python文件路径操作方法总结
  20. apple tv 开发_现在是购买Apple TV的好时机吗?

热门文章

  1. MyEclipse清除已永久保存的SVN账号
  2. 台式电脑计算机硬盘清理,怎样清理台式电脑硬盘垃圾
  3. 2023武汉理工大学计算机考研信息汇总
  4. C++代码破解LOL人物基址特征,基址在源码里面自己找!
  5. 分享几个我常用渗透网站
  6. 7-20 sdust-Java-字符串集合求并集
  7. iOS系统越狱研究现状梳理
  8. OpenGL进阶(十九) - 多光源
  9. 终点条件下的轨迹预测:It is not the Journey but the Destination: Endpoint Conditioned Trajectory Prediction
  10. nbu客户端卸载_在LINUX系统下如何卸载NetBackup