python logging模块的使用详解


Posted in Python onOctober 23, 2020

logging日志模块:是用来记录日志的模块,一般记录用户在软件中的操作

使用方法:模板直接拿来用,手动修改

# logging的配置信息(模板)
import os
import logging.config


# 定义三种日志输出格式 开始(模板,不用配置,直接拿来用)
standard_format = '[%(asctime)s][%(threadName)s:%(thread)d][task_id:%(name)s][%(filename)s:%(lineno)d]' \
         '[%(levelname)s][%(message)s]' # 其中name为get_logger中指定的名字
simple_format = '[%(levelname)s][%(asctime)s][%(filename)s:%(lineno)d]%(message)s'
id_simple_format = '[%(levelname)s][%(asctime)s] %(message)s'
# 定义日志输出格式 结束


# (*****)注意1: log文件的目录(手动修改)
BASE_PATH = os.path.dirname(os.path.dirname(__file__))  # 获取项目路径
logfile_dir = os.path.join(BASE_PATH, 'log')  # 存放log文件的目录
# (*****)注意2: log文件名(手动修改)
logfile_name = 'user.log'


# 如果不存在定义的日志目录就创建一个
if not os.path.isdir(logfile_dir):
  os.mkdir(logfile_dir)
# log文件的全路径
logfile_path = os.path.join(logfile_dir, logfile_name)


# (*****)注意3: log配置字典(模板,不用配置,直接拿来用)
LOGGING_DIC = {
  'version': 1,
  'disable_existing_loggers': False,
  'formatters': {
    'standard': {
      'format': standard_format
    },
    'simple': {
      'format': simple_format
    },
  },
  'filters': {},
  'handlers': {
    # 打印到终端的日志
    'console': {
      'level': 'DEBUG',
      'class': 'logging.StreamHandler', # 打印到屏幕
      'formatter': 'simple'
    },
    # 打印到文件的日志,收集info及以上的日志
    'default': {
      'level': 'DEBUG',
      'class': 'logging.handlers.RotatingFileHandler', # 保存到文件
      'formatter': 'standard',
      'filename': logfile_path, # 日志文件
      'maxBytes': 1024 * 1024 * 5, # 日志大小 5M
      'backupCount': 5,
      'encoding': 'utf-8', # 日志文件的编码,再也不用担心中文log乱码了
    },
  },
  'loggers': {
    # logging.getLogger(__name__)拿到的logger配置
    '': {
      'handlers': ['default', 'console'], # 这里把上面定义的两个handler都加上,即log数据既写入文件又打印到屏幕
      'level': 'DEBUG',
      'propagate': True, # 向上(更高level的logger)传递
    },
  },
}


# (*****)注意4:定义日志函数,传入的参数可以是日志信息中的"用户id"或者"用户名字",也可以是某一类型的统称
def get_logger(user_type):
  # 1.加载log配置字典到logging模块的配置中
  logging.config.dictConfig(LOGGING_DIC)
  # 2.获取日志对象
  # logger = logging.getLogger('user')
  # logger = logging.getLogger('bank')
  # logger = logging.getLogger('shop')
  logger = logging.getLogger(user_type)
  return logger

# 调用函数,记录日志# 通过logger日志对象,调用内部的日志打印
logger = get_logger('user')  # 这里的参数为日志信息中的"用户id"或者"用户名字"
# 调用获取日志函数的日志对象
# logger.debug('学习不要浮躁,一步一个脚印!')
logger.info('学习不要浮躁,一步一个脚印!')  # debug和info均为日志等级,用info即可,info后面传入的内容就是需要记录日志的内容

注意:前三个注意点可以根据情况修改设置,第四个注意点是log的配置字典,无需修改,只需留意即可。

执行结果:

[INFO][2020-10-22 20:23:07,405][04 logging模块.py:100]学习不要浮躁,一步一个脚印!

logging模块应用输出示例:

python logging模块的使用详解

python logging模块的使用详解

以上就是python logging模块的使用详解的详细内容,更多关于python logging模块的资料请关注三水点靠木其它相关文章!

Python 相关文章推荐
python的即时标记项目练习笔记
Sep 18 Python
17个Python小技巧分享
Jan 23 Python
使用url_helper简化Python中Django框架的url配置教程
May 30 Python
python统计cpu利用率的方法
Jun 02 Python
通过Python实现自动填写调查问卷
Sep 06 Python
python递归实现快速排序
Aug 18 Python
Linux下远程连接Jupyter+pyspark部署教程
Jun 21 Python
详解python uiautomator2 watcher的使用方法
Sep 09 Python
使用python修改文件并立即写回到原始位置操作(inplace读写)
Jun 28 Python
python批量修改交换机密码的示例
Sep 22 Python
python MD5加密的示例
Oct 19 Python
只用20行Python代码实现屏幕录制功能
Jun 02 Python
Pycharm自动添加文件头注释和函数注释参数的方法
Oct 23 #Python
Python中免验证跳转到内容页的实例代码
Oct 23 #Python
python对 MySQL 数据库进行增删改查的脚本
Oct 22 #Python
Python提取视频中图片的示例(按帧、按秒)
Oct 22 #Python
详解python模块pychartdir安装及导入问题
Oct 22 #Python
Python实现自动装机功能案例分析
Oct 22 #Python
Python reversed反转序列并生成可迭代对象
Oct 22 #Python
You might like
用php的ob_start来生成静态页面的方法分析
2011/03/09 PHP
php可扩展的验证类实例(可对邮件、手机号、URL等验证)
2015/07/09 PHP
php如何连接sql server
2015/10/16 PHP
PHP运用foreach神奇的转换数组(实例讲解)
2018/02/01 PHP
javascript 写类方式之四
2009/07/05 Javascript
jQuery 第二课 操作包装集元素代码
2010/03/14 Javascript
javascript检测页面是否缩放的小例子
2013/05/16 Javascript
jquery实现控制表格行高亮实例
2013/06/05 Javascript
JavaScript定时器详解及实例
2013/08/01 Javascript
js通过location.search来获取页面传来的参数
2014/09/11 Javascript
百度UEditor编辑器如何关闭抓取远程图片功能
2015/03/03 Javascript
jquery处理页面弹出层查询数据等待操作实例
2015/03/25 Javascript
jQuery配合coin-slider插件制作幻灯片效果的流程解析
2016/05/13 Javascript
jQuery悬停文字提示框插件jquery.tooltipster.js用法示例【附demo源码下载】
2016/07/19 Javascript
JavaScript性能优化之函数节流(throttle)与函数去抖(debounce)
2016/08/11 Javascript
jquery动态添加带有样式的HTML标签元素方法
2018/02/24 jQuery
layer弹出层自定义提交取消按钮的例子
2019/09/10 Javascript
[08:02]DOTA2牵红线 zhou神抱得美人归
2014/03/22 DOTA
[46:03]LGD vs VGJ.T 2018国际邀请赛小组赛BO2 第一场 8.16
2018/08/17 DOTA
Python字符串和字典相关操作的实例详解
2017/09/23 Python
python基础之包的导入和__init__.py的介绍
2018/01/08 Python
Python SqlAlchemy动态添加数据表字段实例解析
2018/02/07 Python
对pandas进行数据预处理的实例讲解
2018/04/20 Python
Python实现全排列的打印
2018/08/18 Python
Python实现的在特定目录下导入模块功能分析
2019/02/11 Python
python3实现微型的web服务器
2019/09/03 Python
使用Tensorflow-GPU禁用GPU设置(CPU与GPU速度对比)
2020/06/30 Python
关于Python 解决Python3.9 pandas.read_excel(‘xxx.xlsx‘)报错的问题
2020/11/28 Python
10分钟入门CSS3 Animation
2018/12/25 HTML / CSS
项目合作意向书模板
2014/07/29 职场文书
出生医学证明书
2014/09/15 职场文书
开场白怎么写
2015/06/01 职场文书
雷锋之歌观后感
2015/06/10 职场文书
python实现自动化群控的步骤
2021/04/11 Python
用Python写一个简易版弹球游戏
2021/04/13 Python
Python数据分析之pandas函数详解
2021/04/21 Python