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开发框架网发布内容,转载请附上原文出处连接
管理员
上一篇:Python修改cmd窗口标题
下一篇:gitblit服务器配置指南
评论列表

发表评论

评论内容
昵称:
关联文章

Python 打印日志格式,并且支持不同颜色背景
Python 重构Print 日志记录
css两种颜色边框设置,边框设置多种颜色
在Winform项目Web API的.NetCore项目中使用Serilog 来记录日志信息
CSS鼠标hover 背景动画煽动效果
Excel自定义格式千分符
iNeuOS工业互联网操作系统,分布式云端控制安全策略增加实时日志功能
python四种配置文件
Python pyinstaller 打包参数说明
使用 mitmproxy + python 做拦截代理
日志级别的选择:Debug、Info、Warn、Error还是Fatal
.net 简单实现在H5中将word、jpg、png转成PDF给PDF添加水印并且控制样式可视化编辑
C# RSA加密(私钥加密、公钥解密、密钥格式转换、支持超大长度分段加密)
Python使用SQL Server数据库
winform使用webBrowser,C#直接调用js函数,并且支持array数组
TextBox支持拖拽路径文件
Winform开发框架日志管理
页面快排插件配置支持图片上传
iNeuOS工业互联网操作系统,发布3.6.4版本:云端安全控制实时日志功能,附Chrome、FirefoxEdge浏览器测试性能对比
自己创造一个格式,自定义文件后缀名

联系我们
联系电话:15090125178(微信同号)
电子邮箱:garson_zhang@163.com
站长微信二维码
微信二维码