python实现log日志的示例代码


Posted in Python onApril 28, 2018

源代码:

# coding=utf-8
import logging
import os
import time
LEVELS={'debug':logging.DEBUG,\
  'info':logging.INFO,\
  'warning':logging.WARNING,\
  'error':logging.ERROR,\
  'critical':logging.CRITICAL,}
  
logger=logging.getLogger()
level='default'
def createFile(filename):
 path=filename[0:filename.rfind('/')]
 if not os.path.isdir(path):
  os.makedirs(path)
 if not os.path.isfile(filename):
#创建并打开一个新文件
  fd = open(filename,mode='w',encoding='utf-8')
  fd.close()
class MyLog:
 log_filename='E:/quality/it/pyrequest-master/log/itest.log'
 err_filename='E:/quality/it/pyrequest-master/log/err.log'
 dateformat='%Y-%m-%d %H:%M:%S'
 logger.setLevel(LEVELS.get(level,logging.NOTSET))
 createFile(log_filename)
 createFile(err_filename)
#注意文件内容写入时编码格式指定
 handler=logging.FileHandler(log_filename,encoding='utf-8')
 errhandler=logging.FileHandler(err_filename,encoding='utf-8')
 @staticmethod 
 #静态方法
 def debug(log_message):
  setHandler('debug')
  logger.debug("[DEBUG "+getCurrentTime()+"]"+log_message)
  removerhandler('debug')
 @staticmethod
 def info(log_message):
  setHandler('info')
  logger.info("[INFO "+getCurrentTime()+"]"+log_message)
  removerhandler('info')
 
 @staticmethod
 def warning(log_message):
  setHandler('warning')
  logger.warning("[WARNING "+getCurrentTime()+"]"+log_message)
  removerhandler('warning')
 @staticmethod
 def error(log_message):
  setHandler('error')
  logger.error("[ERROR "+getCurrentTime()+"]"+log_message)
  removerhandler('error')
 @staticmethod
 def critical(log_message):
  setHandler('critical')
  logger.critical("[CRITICAL "+getCurrentTime()+"]"+log_message)
  removerhandler('critical')
# logger可以看做是一个记录日志的人,对于记录的每个日志,他需要有一套规则,比如记录的格式(formatter),
# 等级(level)等等,这个规则就是handler。使用logger.addHandler(handler)添加多个规则,
# 就可以让一个logger记录多个日志。
def setHandler(level):
 if level=='error':
  logger.addHandler(MyLog.errhandler)
 #handler=logging.FileHandler(log_filename)
 #把logger添加上handler
 logger.addHandler(MyLog.handler)
def removerhandler(level):
 if level=='error':
  logger.removeHandler(MyLog.errhandler)
 logger.removeHandler(MyLog.handler)
def getCurrentTime():
 return time.strftime(MyLog.dateformat,time.localtime(time.time()))
if __name__=="__main__":
 MyLog.debug("This is debug message")
 MyLog.info("This is info message")
 MyLog.warning("This is warning message")
 MyLog.error("This is error message")
 MyLog.critical("This is critical message")

以上这篇python实现log日志的示例代码就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
举例介绍Python中的25个隐藏特性
Mar 30 Python
浅谈python装饰器探究与参数的领取
Dec 01 Python
Python使用pip安装报错:is not a supported wheel on this platform的解决方法
Jan 23 Python
Django 跨域请求处理的示例代码
May 02 Python
python爬取足球直播吧五大联赛积分榜
Jun 13 Python
Python 学习教程之networkx
Apr 15 Python
python系列 文件操作的代码
Oct 06 Python
利用pytorch实现对CIFAR-10数据集的分类
Jan 14 Python
python 使用while循环输出*组成的菱形实例
Apr 12 Python
从0到1使用python开发一个半自动答题小程序的实现
May 12 Python
python字典与json转换的方法总结
Dec 28 Python
Jupyter Notebook 安装配置与使用详解
Jan 06 Python
Python学习笔记之open()函数打开文件路径报错问题
Apr 28 #Python
Python之读取TXT文件的方法小结
Apr 27 #Python
如何利用python查找电脑文件
Apr 27 #Python
Python3 中把txt数据文件读入到矩阵中的方法
Apr 27 #Python
python Spyder界面无法打开的解决方法
Apr 27 #Python
解决Spyder中图片显示太小的问题
Apr 27 #Python
Python 读取图片文件为矩阵和保存矩阵为图片的方法
Apr 27 #Python
You might like
初识PHP
2014/09/28 PHP
WampServer下安装多个版本的PHP、mysql、apache图文教程
2015/01/07 PHP
php生成短域名函数
2015/03/23 PHP
深入解析PHP的Yii框架中的缓存功能
2016/03/29 PHP
PHP简单获取及判断提交来源的方法
2016/04/22 PHP
深入剖析PHP中printf()函数格式化使用
2016/05/23 PHP
redis+php实现微博(二)发布与关注功能详解
2019/09/23 PHP
php操作redis命令及代码实例大全
2020/11/19 PHP
SOSO地图JS画出标注和中心点以html形式运行
2013/08/09 Javascript
js匿名函数的调用示例(形式多种多样)
2014/08/20 Javascript
JavaScript模拟数组合并concat
2016/03/06 Javascript
使用JS实现图片展示瀑布流效果(简单实例)
2016/09/06 Javascript
基于jQuery和Bootstrap框架实现仿知乎前端动态列表效果
2016/11/09 Javascript
mui开发中获取单选按钮、复选框的值(实例讲解)
2017/07/24 Javascript
mpvue中配置vuex并持久化到本地Storage图文教程解析
2018/03/15 Javascript
微信小程序访问豆瓣电影api的实现方法
2019/03/31 Javascript
vue实现行列转换的一种方法
2019/08/06 Javascript
详解JavaScript修改注册表的方法
2020/01/05 Javascript
如何配置vue.config.js 处理static文件夹下的静态文件
2020/06/19 Javascript
Vue中nprogress页面加载进度条的方法实现
2020/11/13 Javascript
微信小程序实现分页加载效果
2020/11/19 Javascript
Node.js中的异步生成器与异步迭代详解
2021/01/31 Javascript
JavaScript 判断浏览器是否是IE
2021/02/19 Javascript
[01:46]DOTA2上海特锦赛小组赛英文解说KotlGuy采访
2016/02/27 DOTA
keras模型保存为tensorflow的二进制模型方式
2020/05/25 Python
CSS3 网页下拉菜单代码解释 中文翻译
2010/02/27 HTML / CSS
CSS3 border-image详解、应用及jQuery插件
2011/08/29 HTML / CSS
css图标制作教程制作云图标
2014/01/19 HTML / CSS
维护民族团结演讲稿
2014/08/27 职场文书
商品陈列协议书
2014/09/29 职场文书
宾馆卫生管理制度
2015/08/06 职场文书
2019假期福利管理制度!
2019/07/15 职场文书
导游词之烟台威海蓬莱
2019/11/14 职场文书
80行代码写一个Webpack插件并发布到npm
2021/05/24 Javascript
React + Threejs + Swiper 实现全景图效果的完整代码
2021/06/28 Javascript
拙作再改《我的收音机情缘》
2022/04/05 无线电