在开发项目过程中,为了方便调试代码,经常会向stdout中输出一些日志,默认的这些日志就直接显示在了终端中。而一般的应用服务器,第三方库,甚至服务器的一些通告也会在终端中显示,这样就搅乱了我们想要的信息。
书写格式,和相关说明如下:
1 格式:\033[显示方式;前景色;背景色m
2
3 说明:
4 前景色 背景色 颜色
5 ---------------------------------------
6 30 40 黑色
7 31 41 红色
8 32 42 绿色
9 33 43 黃色
10 34 44 蓝色
11 35 45 紫红色
12 36 46 青蓝色
13 37 47 白色
14 显示方式 意义
15 -------------------------
16 0 终端默认设置
17 1 高亮显示
18 4 使用下划线
19 5 闪烁
20 7 反白显示
21 8 不可见
22
23 例子:
24 \033[1;31;40m <!--1-高亮显示 31-前景色红色 40-背景色黑色-->
25 \033[0m <!--采用终端默认设置,即取消颜色设置-->
也许你希望在终端上输出一些带有颜色或者粗体、下划线等样式的信息,就像man中的那样,那么这篇文章将会起到些许作用。
在Linux终端中,使用转义序列来进行如上所述的显示,转义序列以ESC开头,即ASCII码下的\033,其格式为:
\033[显示方式;前景色;背景色m
显示方式、前景色、背景色至少一个存在即可。
其中:
显示方式:0(关闭所有效果),1(高亮),4(下划线),5(闪烁),7(反色),8(不可见)。
前景色以3开头,背景色以4开头,具体颜色值有:0(黑色),1(红色),2(绿色),3(黄色),4(蓝色),5(紫色),6(青色),7(白色)。即前景绿色为32,背景蓝色为44。
下面是Python程序编写的输出样式脚本:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
#! /usr/bin/python
# -*- coding: utf-8
STYLE = {
'fore': {
'black': 30, 'red': 31, 'green': 32, 'yellow': 33,
'blue': 34, 'purple': 35, 'cyan': 36, 'white': 37,
},
'back': {
'black': 40, 'red': 41, 'green': 42, 'yellow': 43,
'blue': 44, 'purple': 45, 'cyan': 46, 'white': 47,
},
'mode': {
'bold': 1, 'underline': 4, 'blink': 5, 'invert': 7,
},
'default': {
'end': 0,
}
}
def use_style(string, mode='', fore='', back=''):
mode = '%s' % STYLE['mode'][mode] if STYLE['mode'].has_key(mode) else ''
fore = '%s' % STYLE['fore'][fore] if STYLE['fore'].has_key(fore) else ''
back = '%s' % STYLE['back'][back] if STYLE['back'].has_key(back) else ''
style = ';'.join([s for s in [mode, fore, back] if s])
style = '\033[%sm' % style if style else ''
end = '\033[%sm' % STYLE['default']['end'] if style else ''
return '%s%s%s' % (style, string, end)
def test():
print use_style('Normal')
print use_style('Bold', mode='bold')
print use_style('Underline & red text', mode='underline', fore='red')
print use_style('Invert & green back', mode='reverse', back='green')
print use_style('Black text & White back', fore='black', back='white')
if __name__ == '__main__':
test()
|
其显示效果如下图所示:
