python对日志进行处理的实例代码


Posted in Python onOctober 06, 2018

平时做数据处理基本离不了日志记录功能。每次都配置一堆挺烦人,索性封装个模块,这里记录一下,与大家共享。
说明

本日志模块目前只有一个方法getLogger,其他配置项通过参数传递,包括日志文件名,等级,日志文件划分方式,日志清除配置,日志格式等。

logger.py

import loggin

gfrom logging import handlers

# 日志级别字典

__level_dict = {  

'critical': logging.CRITICAL,  

'fatal': logging.CRITICAL,  

'error': logging.ERROR,  

 'warning': logging.WARNING,  

 'warn': logging.WARNING,  

 'info': logging.INFO,  

 'debug': logging.DEBUG

}

def getLogger(filename, level='info', when='D', backupCount=3,

       fmt='%(asctime)s - %(pathname)s[line:%(lineno)d] - %(levelname)s: %(message)s'):

  """

  获取日志处理对象

 

  :param filename: 日志文件名称

  :param level: 日志等级:debug, info, warn/warning, error, critical

  :param when: 日志文件分割的时间单位,单位有以下几种:<br>

        - S 秒<br>

        - M 分<br>

        - H 小时<br>

        - D 天<br>

        - W 每星期<br>

        - midnight 每天凌晨<br>

  :param backupCount: 备份文件的个数,如果超过这个数量,就会自动删除

  :param fmt: 日志信息格式

  :return:

  """

  level = __level_dict.get(level.lower(), None)

  logger = logging.getLogger(filename)  # 设置日志格式

  format_str = logging.Formatter(fmt)  # 设置日志级别

  logger.setLevel(level)  # 控制台输出

  console_handler = logging.StreamHandler()  # 控制台输出的格式

  console_handler.setFormatter(format_str)

  logger.addHandler(console_handler)  # 文件输出

  file_handler = handlers.TimedRotatingFileHandler(filename=filename, when=when, backupCount=backupCount,

                           encoding='utf-8')  # 文件输出的格式

  file_handler.setFormatter(format_str) 

  logger.addHandler(file_handler)  return loggerif __name__ == '__main__':

  log = getLogger('test.log')

  log.debug('debug')

  log.info('info')

  log.warning('警告')

  log.error('报错')

  log.critical('严重')

  getLogger('error.log', level='error').error('error')

运行结果

2018-09-06 17:07:40,909 - D:/jetbrains/workspace-pycharm/test/logger.py[line:59] - INFO: info
2018-09-06 17:07:40,909 - D:/jetbrains/workspace-pycharm/test/logger.py[line:60] - WARNING: 警告
2018-09-06 17:07:40,909 - D:/jetbrains/workspace-pycharm/test/logger.py[line:61] - ERROR: 报错
2018-09-06 17:07:40,910 - D:/jetbrains/workspace-pycharm/test/logger.py[line:62] - CRITICAL: 严重
2018-09-06 17:07:40,915 - D:/jetbrains/workspace-pycharm/test/logger.py[line:63] - ERROR: erro

以上就是本次相关知识点的全部内容和代码,感谢大家对三水点靠木的支持。

Python 相关文章推荐
Python编程中使用Pillow来处理图像的基础教程
Nov 20 Python
使用Python生成XML的方法实例
Mar 21 Python
详解Python 模拟实现生产者消费者模式的实例
Aug 10 Python
对Python模块导入时全局变量__all__的作用详解
Jan 11 Python
在numpy矩阵中令小于0的元素改为0的实例
Jan 26 Python
Python静态类型检查新工具之pyright 使用指南
Apr 26 Python
python实现银行管理系统
Oct 25 Python
Python3 字典dictionary入门基础附实例
Feb 10 Python
为什么称python为胶水语言
Jun 16 Python
python中数字是否为可变类型
Jul 08 Python
python 爬虫网页登陆的简单实现
Nov 30 Python
编写python程序的90条建议
Apr 14 Python
浅析Python函数式编程
Oct 06 #Python
Python实现iOS自动化打包详解步骤
Oct 03 #Python
Python中GIL的使用详解
Oct 03 #Python
Python线程同步的实现代码
Oct 03 #Python
详解通过API管理或定制开发ECS实例
Sep 30 #Python
Python 使用类写装饰器的小技巧
Sep 30 #Python
浅谈django三种缓存模式的使用及注意点
Sep 30 #Python
You might like
PHP has encountered an Access Violation at 7C94BD02解决方法
2009/08/24 PHP
Yii结合CKEditor实现图片上传功能
2014/06/13 PHP
phpmailer在服务器上不能正常发送邮件的解决办法
2014/07/08 PHP
如何让搜索引擎抓取AJAX内容解决方案
2014/08/25 PHP
php导出生成word的方法
2015/12/25 PHP
Windows2003下php5.4安装配置教程(Apache2.4)
2016/06/30 PHP
Laravel 5.5官方推荐的Nginx配置学习教程
2017/10/06 PHP
Prototype使用指南之dom.js
2007/01/10 Javascript
JavaScript类和继承 constructor属性
2010/03/04 Javascript
JavaScript高级程序设计 读书笔记之十一 内置对象Global
2012/03/07 Javascript
js实现鼠标感应向下滑动隐藏菜单的方法
2015/02/20 Javascript
JS正则表达式学习之贪婪和非贪婪模式实例总结
2016/12/26 Javascript
详解webpack打包时排除其中一个css、js文件或单独打包一个css、js文件(两种方法)
2018/10/26 Javascript
微信小程序使用自定义组件导航实现当前页面高亮
2020/01/02 Javascript
js实现简单的打印表格
2020/01/15 Javascript
JS中==、===你分清楚了吗
2020/03/04 Javascript
vue制作抓娃娃机的示例代码
2020/04/17 Javascript
NestJs使用Mongoose对MongoDB操作的方法
2021/02/22 Javascript
[03:42]2014DOTA2西雅图国际邀请赛 Navi战队巡礼
2014/07/07 DOTA
python使用socket进行简单网络连接的方法
2015/04/29 Python
Python+tkinter模拟“记住我”自动登录实例代码
2018/01/16 Python
VSCode下配置python调试运行环境的方法
2018/04/06 Python
对python中for、if、while的区别与比较方法
2018/06/25 Python
Python Socket TCP双端聊天功能实现过程详解
2020/06/15 Python
如何用Anaconda搭建虚拟环境并创建Django项目
2020/08/02 Python
网页中的电话号码如何实现一键直呼效果_附示例
2016/03/15 HTML / CSS
印度最好的在线药品订购网站:PharmEasy
2018/11/30 全球购物
反洗钱宣传活动总结
2014/08/26 职场文书
相亲活动方案
2014/08/26 职场文书
政风行风评议工作总结
2014/10/21 职场文书
党的群众路线教育实践活动个人对照检查材料(公安)
2014/11/05 职场文书
2014年销售员工作总结
2014/12/01 职场文书
2015年大学宣传部工作总结
2015/05/26 职场文书
多人股份制合作协议书
2016/03/19 职场文书
[有人@你]你有一封绿色倡议书,请查收!
2019/07/18 职场文书
导游词之天下银坑景区
2019/11/21 职场文书