如果你的意思是上色LogRecord
而已,你可以在settings.py
與ANSI轉義代碼定製LOG_FORMAT
設置爲相同的格式。
例子:
LOG_FORMAT = '\x1b[0;0;34m%(asctime)s\x1b[0;0m \x1b[0;0;36m[%(name)s]\x1b[0;0m \x1b[0;0;31m%(levelname)s\x1b[0;0m: %(message)s'
如果你也想上色用不同的顏色不同的日誌級別,可以覆蓋scrapy.utils.log._get_handler
(source code)。
將這個靠近頂部的settings.py
import scrapy.utils.log
_get_handler = copy.copy(scrapy.utils.log._get_handler)
def _get_handler_custom(*args, **kwargs):
handler = _get_handler(*args, **kwargs)
handler.setFormatter(your_custom_formatter)
return handler
scrapy.utils.log._get_handler = _get_handler_custom
它的作用是重新格式化調用原_get_handler
後,然後將其重新連接到scrapy.utils.log
。 這是一個拙劣的解決方案,可能不是最好的做法,但它只是起作用。
實現此目的更正確的方法是覆蓋logging.StreamHandler
。 SO上有a bunch of discussion,這可以引導你走向正確的方向。
在這裏,我提供了我在項目中使用的完整工作代碼(第三方包colorlog
正在使用中)。
settings.py
import copy
from colorlog import ColoredFormatter
import scrapy.utils.log
color_formatter = ColoredFormatter(
(
'%(log_color)s%(levelname)-5s%(reset)s '
'%(yellow)s[%(asctime)s]%(reset)s'
'%(white)s %(name)s %(funcName)s %(bold_purple)s:%(lineno)d%(reset)s '
'%(log_color)s%(message)s%(reset)s'
),
datefmt='%y-%m-%d %H:%M:%S',
log_colors={
'DEBUG': 'blue',
'INFO': 'bold_cyan',
'WARNING': 'red',
'ERROR': 'bg_bold_red',
'CRITICAL': 'red,bg_white',
}
)
_get_handler = copy.copy(scrapy.utils.log._get_handler)
def _get_handler_custom(*args, **kwargs):
handler = _get_handler(*args, **kwargs)
handler.setFormatter(color_formatter)
return handler
scrapy.utils.log._get_handler = _get_handler_custom