python在终端输出不同颜色的打印,自定义日志和自定义log输出级别

实现过程:

      终端的字符颜色是用转义序列控制的,是文本模式下的系统显示功能,和具体的语言无关。

      转义序列是以ESC开头,即用\033来完成(ESC的ASCII码用十进制表示是27,用八进制表示就是033)。

书写格式:
     开头部分:\033[显示方式;前景色;背景色m + 结尾部分:\033[0m

     注意:开头部分的三个参数:显示方式,前景色,背景色是可选参数,可以只写其中的某一个;另外由于表示三个参数不同含义的数值都是唯一的没有重复的,所以三个参数的书写先后顺序没有固定要求,系统都能识别;但是,建议按照默认的格式规范书写。

     对于结尾部分,其实也可以省略,但是为了书写规范,建议\033[***开头,\033[0m结尾。

数值表示的参数含义:


常见开头格式
\033[0m            默认字体正常显示,不高亮
\033[32;0m       红色字体正常显示
\033[1;32;40m  显示方式: 高亮    字体前景色:绿色  背景色:黑色
\033[0;31;46m  显示方式: 正常    字体前景色:红色  背景色:青色

扫描二维码关注公众号,回复: 4689793 查看本文章

实例:

  (1)print("\033[1;31;40m您输入的帐号或密码错误!\033[0m")  

  上方代码的输出格式为:字体高亮,红色前景,黄色背景      PS:前景色也就是字体的颜色
  

  (2)print("\033[0;31m%s\033[0m" % "输出红色字符")

  #上方代码的输出格式为:字体默认,红色前景

  

LOG_INFO='INFO'
LOG_ERROR='ERROR'
LOG_WARNING='WARNING'
LOG_NOTIFY='NOTIFY'
LOG_DEBUG='DEBUG'
LOG_USER='USER'

import time

#日志水平,0不输出,1输出ERROR,2输出WARNING、ERROR,3输出NOTIFY、WARNING、ERROR
#4输出INFO、NOTIFY、WARNING、ERROR,5输出除DEBUG外的其他,6输出所有包括DEBUG
log_level=5

def get_time_stamp():
    ct = time.time()
    local_time = time.localtime(ct)
    data_head = time.strftime("%Y-%m-%d %H:%M:%S", local_time)
    data_secs = (ct - long(ct)) * 1000
    time_stamp = "%s.%03d" % (data_head, data_secs)
    return time_stamp

def info_log(value):
    if log_level > 3:
        print("\033[37m[%s][info]%s\033[0m"%(get_time_stamp(),value))

def error_log(value):
    if log_level != 0:
        print("\033[31m[%s][error]%s\033[0m"%(get_time_stamp(),value))

def warning_log(value):
    if log_level > 1:
        print("\033[33m[%s][warning]%s\033[0m"%(get_time_stamp(),value))

def debug_log(value):
    if log_level > 5:
        print("\033[34m[%s][debug]%s\033[0m"%(get_time_stamp(),value))

def notify_log(value):
    if log_level > 2:
        print("\033[36m[%s][notify]%s\033[0m"%(get_time_stamp(),value))

def user_log(value):
    if log_level > 4:
        print("\033[32m[%s][user]%s\033[0m"%(get_time_stamp(),value))

def ZLOG(log_type,value):
    switcher={
        'INFO':info_log,
        'ERROR':error_log,
        'WARNING':warning_log,
        'DEBUG':debug_log,
        'NOTIFY':notify_log,
        'USER':user_log
    }
    return switcher[log_type](value)

test = "logtest"
ZLOG(LOG_INFO,"hello" + test)
ZLOG(LOG_ERROR,"hello %s"%test)

猜你喜欢

转载自blog.csdn.net/weixin_42651205/article/details/85287631
今日推荐