2020-03-29 01:22:46 +08:00
|
|
|
import logging
|
|
|
|
import datetime
|
2020-04-08 00:50:39 +08:00
|
|
|
import os
|
|
|
|
import sys
|
2020-04-16 14:05:37 +08:00
|
|
|
from collections import deque
|
2020-03-29 01:22:46 +08:00
|
|
|
|
2020-04-08 00:50:39 +08:00
|
|
|
pyw_name = os.path.splitext(os.path.basename(sys.argv[0]))[0]
|
2020-05-25 22:05:42 +08:00
|
|
|
if '_' in pyw_name:
|
|
|
|
pyw_name = '_'.join(pyw_name.split('_')[:-1])
|
2020-03-29 01:22:46 +08:00
|
|
|
|
|
|
|
logger = logging.getLogger()
|
|
|
|
logger.setLevel(logging.INFO)
|
|
|
|
|
|
|
|
formatter = logging.Formatter(fmt='%(asctime)s.%(msecs)03d | %(levelname)s | %(message)s', datefmt='%Y-%m-%d %H:%M:%S')
|
|
|
|
|
|
|
|
console = logging.StreamHandler()
|
|
|
|
console.setFormatter(formatter)
|
|
|
|
logger.addHandler(console)
|
|
|
|
|
2020-04-08 00:50:39 +08:00
|
|
|
log_file = f'./log/{datetime.date.today()}_{pyw_name}.txt'
|
|
|
|
try:
|
|
|
|
file = logging.FileHandler(log_file)
|
|
|
|
except FileNotFoundError:
|
|
|
|
os.mkdir('./log')
|
|
|
|
file = logging.FileHandler(log_file)
|
2020-03-29 01:22:46 +08:00
|
|
|
file.setFormatter(formatter)
|
|
|
|
logger.addHandler(file)
|
|
|
|
|
|
|
|
|
|
|
|
def hr(title, level=3):
|
|
|
|
title = str(title).upper()
|
|
|
|
if level == 1:
|
|
|
|
logger.info('=' * 20 + ' ' + title + ' ' + '=' * 20)
|
|
|
|
if level == 2:
|
|
|
|
logger.info('-' * 20 + ' ' + title + ' ' + '-' * 20)
|
|
|
|
if level == 3:
|
|
|
|
logger.info('<' * 3 + ' ' + title + ' ' + '>' * 3)
|
|
|
|
if level == 0:
|
|
|
|
middle = '|' + ' ' * 20 + title + ' ' * 20 + '|'
|
|
|
|
border = '+' + '-' * (len(middle) - 2) + '+'
|
|
|
|
logger.info(border)
|
|
|
|
logger.info(middle)
|
|
|
|
logger.info(border)
|
|
|
|
|
|
|
|
|
|
|
|
def attr(name, text):
|
|
|
|
logger.info('[%s] %s' % (str(name), str(text)))
|
|
|
|
|
|
|
|
|
|
|
|
logger.hr = hr
|
|
|
|
logger.attr = attr
|
2020-05-22 21:48:56 +08:00
|
|
|
logger.screenshot_deque = deque(maxlen=60)
|
2020-03-29 01:22:46 +08:00
|
|
|
|
|
|
|
logger.hr('Start', level=0)
|