-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmy_logger.py
80 lines (64 loc) · 2.54 KB
/
my_logger.py
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#!/usr/bin/env python3
# -*- coding: utf-8 -*-
' a logger module '
__author__ = 'Shea Jin'
import logging
import logging.handlers
import os
import sys
sys.path.append('../') # 新加入的
#用字典保存日志级别
format_dict = {
1 : logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s'),
2 : logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s'),
3 : logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s'),
4 : logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s'),
5 : logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
}
# 开发一个日志系统, 既要把日志输出到控制台, 还要写入日志文件
class Logger():
def __init__(self, logger):
'''
指定保存日志的文件路径,日志级别,以及调用文件
将日志存入到指定的文件中
'''
# 创建一个logger
self.logger = logging.getLogger(logger)
self.logger.setLevel(logging.INFO)
# 创建一个handler,用于写入日志文件
# fh = logging.FileHandler(logname)
# fh.setLevel(logging.DEBUG)
#把日志写入这个文件,如果文件夹不存在就创建
if not os.path.exists('../log'):
os.mkdir('../log')
#存储最近7天的错误跟踪日志,超过7天就删除
time_handler = logging.handlers.TimedRotatingFileHandler('../log/error_log', when='D', interval=1, backupCount=7)
time_handler.suffix = '%Y-%m-%d.log'
#只要是日志级别大于WARNING,就会写入文件
time_handler.setLevel(logging.WARNING)
# 再创建一个handler,用于输出到控制台
console_hanlder = logging.StreamHandler()
console_hanlder.setLevel(logging.INFO)
# 定义handler的输出格式
# formatter = logging.Formatter('%(asctime)s - %(name)s - %(levelname)s - %(message)s')
formatter = format_dict[5]
time_handler.setFormatter(formatter)
console_hanlder.setFormatter(formatter)
# 给logger添加handler
self.logger.addHandler(time_handler)
self.logger.addHandler(console_hanlder)
def getlog(self):
return self.logger
# @classmethod
# def test(self):
# print('hah')
if __name__ == '__main__':
logger = Logger(logger="Shea").getlog()
try:
print('try')
i = 10/0
except BaseException as e:
print('yic')
logger.error('错误')
print('token')
# Logger.test()