一个日志模板,从traceback打印异常受启发做的模板,可被pycharm esclip 等ide识别和跳转
之前发过日志,再增加一种模板。
logging.Formatter('%(asctime)s - %(name)s - File "%(pathname)s", line %(lineno)d, in<%(funcName)s> - %(levelname)s - %(message)s', "%Y-%m-%d %H:%M:%S"), # 一个模仿traceback异常的可跳转到打印日志地方的模板
此模板是模拟traceback字符串的格式,因为traceback字符串被pycahrm等ide支持成跳转了,按照那个格式做日志模板,那么pycharm 控制台和日志文件都能很轻松跳转到指定文件的指定行。
使用pip安装:
pip install -i https://pypi.org/simple/ --upgrade multiprocessing_log_manager 可以不指定安装源,阿里和豆瓣的镜像是定时更新pypi官方包。
模板3
控制台的日志是这样,可以直接点击链接,自动跳转到指定文件的指定行。
模板4,对pycahrm更友好
使用模板4,将自动识别linux系统,由于pycahrm在背景的反着色上有些不美观,所以在win上使用上面的样式 当python程序判断运行的是linux系统,日志将自动切换模板,样式如下

发出针对streamhandler的单独优化的handler
class ColorHandler(logging.Handler):
"""彩色日志,根据不同级别的日志显示不同颜色""" def __init__(self, filter_logger_name_list=None):
logging.Handler.__init__(self)
self.formatter_new = logging.Formatter(
'%(asctime)s - %(name)s - "%(filename)s" - %(funcName)s - %(lineno)d - %(levelname)s - %(message)s',
"%Y-%m-%d %H:%M:%S")
# 对控制台日志单独优化显示和跳转,单独对字符串某一部分使用特殊颜色,主要用于第四种模板,以免filehandler和mongohandler中带有\033 @classmethod
def _my_align(cls, string, length):
if len(string) > length *2:
return string
custom_length = 0
for w in string:
custom_length += 1 if cls._is_ascii_word(w) else 2
if custom_length < length:
place_length = length - custom_length
string += ' ' * place_length
return string @staticmethod
def _is_ascii_word(w):
if ord(w) < 128:
return True def emit(self, record):
"""
30 40 黑色
31 41 红色
32 42 绿色
33 43 黃色
34 44 蓝色
35 45 紫红色
36 46 青蓝色
37 47 白色
:type record:logging.LogRecord
:return:
""" if self.formatter is formatter_dict[4] or self.formatter is self.formatter_new:
self.formatter = self.formatter_new
if os.name == 'nt':
self.__emit_for_fomatter4_pycahrm(record) # 如果是使用第四种模板,并且是pycahrm运行py文件
else:
self.__emit_for_fomatter4_linux(record) # 如果是使用第四种模板,是在linux上运行py文件
else:
self.__emit(record) # 如果是使用第1 2 3 种模板 def __emit_for_fomatter4_linux(self, record):
try:
msg = self.format(record)
file_formatter = ' ' * 10 + '\033[7mFile "%s", line %d\033[0m' % (record.pathname, record.lineno)
if record.levelno == 10:
print('\033[0;32m%s' % self._my_align(msg, 150) + file_formatter)
elif record.levelno == 20:
print('\033[0;96m%s' % self._my_align(msg, 150) + file_formatter)
elif record.levelno == 30:
print('\033[0;33m%s' % self._my_align(msg, 150) + file_formatter)
elif record.levelno == 40:
print('\033[0;35m%s' % self._my_align(msg, 150) + file_formatter)
elif record.levelno == 50:
print('\033[0;31m%s' % self._my_align(msg, 150) + file_formatter)
except (KeyboardInterrupt, SystemExit):
raise
except: # NOQA
self.handleError(record) def __emit_for_fomatter4_pycahrm(self, record):
# \033[0;93;107mFile "%(pathname)s", line %(lineno)d, in %(funcName)s\033[0m
try:
msg = self.format(record)
for_linux_formatter = ' ' * 10 + '\033[7m;File "%s", line %d\033[0m' % (record.pathname, record.lineno)
file_formatter = ' ' * 10 + '\033[0;93;107mFile "%s", line %d\033[0m' % (record.pathname, record.lineno)
if record.levelno == 10:
print('\033[0;32m%s\033[0m' % self._my_align(msg, 200) + file_formatter) # 绿色
elif record.levelno == 20:
print('\033[0;34m%s\033[0m' % self._my_align(msg, 200) + file_formatter) # 青蓝色
elif record.levelno == 30:
print('\033[0;92m%s\033[0m' % self._my_align(msg, 200) + file_formatter) # 蓝色
elif record.levelno == 40:
print('\033[0;35m%s\033[0m' % self._my_align(msg, 200) + file_formatter) # 紫红色
elif record.levelno == 50:
print('\033[0;31m%s\033[0m' % self._my_align(msg, 200) + file_formatter) # 血红色
except (KeyboardInterrupt, SystemExit):
raise
except: # NOQA
self.handleError(record) def __emit(self, record):
try:
msg = self.format(record)
if record.levelno == 10:
print('\033[0;32m%s\033[0m' % msg) # 绿色
elif record.levelno == 20:
print('\033[0;34m%s\033[0m' % msg) # 青蓝色
elif record.levelno == 30:
print('\033[0;92m%s\033[0m' % msg) # 蓝色
elif record.levelno == 40:
print('\033[0;35m%s\033[0m' % msg) # 紫红色
elif record.levelno == 50:
print('\033[0;31m%s\033[0m' % msg) # 血红色
except (KeyboardInterrupt, SystemExit):
raise
except: # NOQA
self.handleError(record)
一个日志模板,从traceback打印异常受启发做的模板,可被pycharm esclip 等ide识别和跳转的更多相关文章
- zoj 2676 dinic模板求实型最小割(可做dinic模板)
#include<stdio.h> #include<string.h> #include<stdlib.h> #include<queue> #inc ...
- python traceback捕获并打印异常
异常处理是日常操作了,但是有时候不能只能打印我们处理的结果,还需要将我们的异常打印出来,这样更直观的显示错误 下面来介绍traceback模块来进行处理 try: 1/0 except Excepti ...
- Springboot + SLF4j + Log4j2 打印异常日志时,耗时要5-6秒
1.使用jps -l 查看springboot项目的进程ID 2.使用命令jstack -l 进程ID > log.txt 打印堆栈信息到文件,内容如下: "http-nio-8065 ...
- 在error日志打印异常
在日志中打印异常,经常会看到以下的写法: logger.error(e.getMessage()); 或者是: e.printStackTrace(); 这两种其实都不太好. e.getMessage ...
- 使用 @Log4j2 log.error() 打印异常日志
public static void main(String[] args) { int a = 10; try { int i = 1/0; } catch (Exception e) { Syst ...
- python日志,支持彩色打印和文件大小切片写入和写入mongodb
1.项目中使用了自定义的ColorHandler和MongoHandler,使用了内置的RotatingFileHandler和三方库的ConcurrentRotatingFileHandler. 支 ...
- Golang把所有包括底层类库,输出到stderr的内容, 重新定向到一个日志文件里面?
不论应用是如何部署的,我们都期望能扑捉到应用的错误日志, 解决思路: 自己写代码处理异常拦截,甚至直接在main函数中写异常拦截. stderr重定向到某个文件里 使用 syscall.Dup2 第一 ...
- Slf4j打印异常的堆栈信息
一.前言 直接用logger.info("异常信息为:"+e)或者logger.info(e.getMessage())只能记录到异常的描述信息,却没有其异常具体发生在哪一行代码. ...
- 主库的wal日志已经被归档或异常丢失如何搭建从库
关键字:wal日志归档 搭建从库 restore_command master 194.1 slave 194.4 wal归档目录 /backup/pgsql/pg_arch/ xlog目录 / ...
随机推荐
- Extjs js 产生Guid或者UUID
Ext.data.IdGenerator.get('uuid').generate() 结果:a9c4efb8-06c9-4c2e-8a70-bb36a69e053e 更多介绍:http://docs ...
- ES 自动恢复分片的时候不恢复了是磁盘超过了85%,然后不恢复了 ES可以配置多个数据目录
ES 自动恢复分片的时候不恢复了是磁盘超过了85%,然后不恢复了 ES可以配置多个数据目录
- ROS关于cv_brige的使用
最近想使用OpenCV 和ROS实现点云的拼接,实现三维重建,那么在学习了kinect的基本的使用方法以后我们知道,直接使用ROS 的包即可得到点云,深度图,rgb图等信息, roslaunch op ...
- nginx日志request_time 和upstream_response_time区别
笔者在根据nginx的accesslog中$request_time进行程序优化时,发现有个接口,直接返回数据,平均的$request_time也比较大.原来$request_time包含了用户数据接 ...
- NetBeans Lookups Explained!
https://dzone.com/articles/netbeans-lookups-explained —————————————————————————————————————————————— ...
- css3常用动画样式文件move.css
move.css zoomIn zoomInDownouter-circlearrowTop expandOpen fadeIn fadeInNormal fadeInUp fadeInRi ...
- MD5骨骼动画模型加载(一)
前面我们分析了静态模型OBJ格式,桢动画模型MD2,这篇主要分析骨骼动画MD5的一些概念并且实现. 混合桢动画有计算简单,容易实现等优点,但是在需要比较细致的效果时,则需要更多的关键桢,每桢都添加相同 ...
- 【转】【Centos】centos 安装libtorrent/rtorrent
1.下载编译时需要的软件 yum install gcc gcc-c++ m4 make automake libtool pkgconfig perl openssl-devel ncurses-d ...
- 利用MATLAB进行曲线拟合
软件环境:MATLAB2013a 一.多项式拟合 多项式拟合是利用多项式最佳地拟合观测数据,使得在观测数据点处的误差平方和最小. 在MATLAB中,利用函数ployfit和ployval进行多项式拟合 ...
- 第三百五十一节,Python分布式爬虫打造搜索引擎Scrapy精讲—将selenium操作谷歌浏览器集成到scrapy中
第三百五十一节,Python分布式爬虫打造搜索引擎Scrapy精讲—将selenium操作谷歌浏览器集成到scrapy中 1.爬虫文件 dispatcher.connect()信号分发器,第一个参数信 ...

