Python 打印日志格式,并且支持不同颜色和背景色
log.py
Python 全选
import os
#! /usr/bin/env python
#coding=utf-8
from time import strftime, localtime
import ctypes,sys
STD_INPUT_HANDLE = -10
STD_OUTPUT_HANDLE = -11
STD_ERROR_HANDLE = -12
# 字体颜色定义 ,关键在于颜色编码,由2位十六进制组成,分别取0~f,前一位指的是背景色,后一位指的是字体色
#由于该函数的限制,应该是只有这16种,可以前景色与背景色组合。也可以几种颜色通过或运算组合,组合后还是在这16种颜色中
# Windows CMD命令行 字体颜色定义 text colors
FOREGROUND_BLACK = 0x00 # black.
FOREGROUND_DARKBLUE = 0x01 # dark blue.
FOREGROUND_DARKGREEN = 0x02 # dark green.
FOREGROUND_DARKSKYBLUE = 0x03 # dark skyblue.
FOREGROUND_DARKRED = 0x04 # dark red.
FOREGROUND_DARKPINK = 0x05 # dark pink.
FOREGROUND_DARKYELLOW = 0x06 # dark yellow.
FOREGROUND_DARKWHITE = 0x07 # dark white.
FOREGROUND_DARKGRAY = 0x08 # dark gray.
FOREGROUND_BLUE = 0x09 # blue.
FOREGROUND_GREEN = 0x0a # green.
FOREGROUND_SKYBLUE = 0x0b # skyblue.
FOREGROUND_RED = 0x0c # red.
FOREGROUND_PINK = 0x0d # pink.
FOREGROUND_YELLOW = 0x0e # yellow.
FOREGROUND_WHITE = 0x0f # white.
# Windows CMD命令行 背景颜色定义 background colors
BACKGROUND_BLUE = 0x10 # dark blue.
BACKGROUND_GREEN = 0x20 # dark green.
BACKGROUND_DARKSKYBLUE = 0x30 # dark skyblue.
BACKGROUND_DARKRED = 0x40 # dark red.
BACKGROUND_DARKPINK = 0x50 # dark pink.
BACKGROUND_DARKYELLOW = 0x60 # dark yellow.
BACKGROUND_DARKWHITE = 0x70 # dark white.
BACKGROUND_DARKGRAY = 0x80 # dark gray.
BACKGROUND_BLUE = 0x90 # blue.
BACKGROUND_GREEN = 0xa0 # green.
BACKGROUND_SKYBLUE = 0xb0 # skyblue.
BACKGROUND_RED = 0xc0 # red.
BACKGROUND_PINK = 0xd0 # pink.
BACKGROUND_YELLOW = 0xe0 # yellow.
BACKGROUND_WHITE = 0xf0 # white.
# get handle
std_out_handle = ctypes.windll.kernel32.GetStdHandle(STD_OUTPUT_HANDLE)
def set_cmd_text_color(color, handle=std_out_handle):
Bool = ctypes.windll.kernel32.SetConsoleTextAttribute(handle, color)
return Bool
#reset white
def resetColor():
set_cmd_text_color(FOREGROUND_RED | FOREGROUND_GREEN | FOREGROUND_BLUE)
###############################################################
def info(*values):
timestr = strftime("%Y-%m-%d %H:%M:%S", localtime())
print(timestr, " | ", *values)
def success(*values):
set_cmd_text_color(BACKGROUND_GREEN | FOREGROUND_WHITE)
info(*values)
resetColor()
def error(*values):
set_cmd_text_color(BACKGROUND_RED | FOREGROUND_WHITE)
info(*values)
resetColor()
def info_gray(*values):
set_cmd_text_color(FOREGROUND_DARKGRAY)
info(*values)
resetColor()
def info_green(*values):
set_cmd_text_color(FOREGROUND_GREEN)
info(*values)
resetColor()
def warning(*values):
set_cmd_text_color(FOREGROUND_DARKYELLOW)
info(*values)
resetColor()
##############################################################
# 测试代码
##############################################################
if __name__ == '__main__':
info(u'log.info普通消息')
info_gray(u'log.info_gray 普通消息 灰色字体')
info_green(u'log.info_green 普通消息 绿色字体')
warning(u'log.warning 普通消息 提醒')
success(u'log.success 成功消息')
error(u'log.error 错误消息')
os.system('pause') #暂停程序
版权声明:本文为YES开发框架网发布内容,转载请附上原文出处连接
post 管理员