ANSI 转义字符串
使用 ANSI 转义序列来实现您想要的,您可以创建一个格式字符串(由 prepended\e[
和 appended表示m
),其中38;5;{0..255}
是文本的 256 色(0..255
是可用颜色代码的范围),并且48;5;{0..255}
是 256 色的背景. 例如,
echo -e "\e[38;5;0;48;5;255mText\e[0m"
将打印0
带有白色背景(颜色代码)的黑色文本(颜色代码255
)。请注意,该echo
命令需要扩展模式(由-e
标志切换)来解释 ANSI 转义字符串。
请注意取消设置颜色的尾随\e[0m
,否则在此命令之后打印的所有文本echo
都将保留格式。\e[0m
重置它。
请注意一个有趣的用例,它也会导致错误。在结束前放置一个感叹号\e[0m
会导致以下输出:
nick@nick-lt:~$ echo -e "\e[38;5;0;48;5;255mText!\e[0m"
bash: !\e[0m: event not found
这是因为!
它是 Bash 字符串扩展的一部分。在此处查看有关此 SO 问题的更多信息。为了使这项工作按预期进行,我们需要做:
echo -e "\e[38;5;0;48;5;255mText"'!'"\e[0m"
因为单引号不会被扩展。
如何使用 ANSI 转义序列打印每种可用颜色。
将这些保存在一个名为的文件中color-functions.sh
:
function color_list_text() {
# First paramter can be an optional background color
local BGCOLOR="$1"
COLOR=
# Loop through the number range 0 to 255
for COLOR in {0..255}; do
local BGCOLORFORM=""
# If our first parameter has a value, then create a background
# format in ANSI escape sequence, assign to $BGCOLORFORM
[[ -z "$BGCOLOR" ]] && BGCOLORFORM="48;5;${BGCOLOR};"
# Create the whole ANSI escape sequence, assign to $TEXTFORM
local TEXTFORM="${BGCOLORFORM}38;5;${COLOR}m"
echo -en "\e[${TEXTFORM} ${COLOR}\t\e[0m"
[[ $(( (COLOR + 1) % 16 )) -eq 0 ]] && echo
done
return 0
}
function color_list_text_backgrounds() {
local TEXTCOLOR="$1"
local COLOR
for COLOR in {0..255}; do
local TEXTCOLORFORM=""
[[ -z "$TEXTCOLOR" ]] && TEXTCOLORFORM="38;5;${TEXTCOLOR};"
local TEXTFORM="${TEXTCOLORFORM}48;5;${COLOR}m"
echo -en "\e[${TEXTFORM} ${COLOR}\t\e[0m"
[[ $(( (COLOR + 1) % 16 )) -eq 0 ]] && echo
done
return 0
}
然后,在另一个文件中,在你source
d 之后调用这些函数:
source color-functions.sh
# Loops through and prints all ANSI escape sequence's available text colors
color_list_text
# Loops through and prints all ANSI escape sequence's available text backgrounds
color_list_backgrounds
这是一个兼具两者的功能......但我认为这有点过头了,因为输出太大(将输出 256 * 256 = 2^16 个组合):
function color_list_text_and_backgrounds() {
local BG
for BG in {0..255}; do
local TEXT
for TEXT in {0..255}; do
echo -en "\e[38;5;${TEXT};48;5;${BG}m ${TEXT}\t\e[0m"
if [[ $(( (TEXT + 1) % 8 )) -eq 0 ]]; then
if [[ $(( ((TEXT + 1) / 8) )) -eq 16 ]]; then
local INVBG=$(( (BG + 128) % 256 ))
echo -en "\e[38;5;${INVBG};48;5;${BG}m ${BG}\t\e[0m"
else
echo -en "\e[48;5;${BG}m\t\e[0m"
fi
echo
fi
done
done
return 0
}
您的用例
要为某些事物着色某些颜色,我们可以使用egrep -i
(-i
标志不区分大小写)和GREP_COLOR
变量:
echo "Some string to color" | \
GREP_COLOR='38;5;200' egrep -i --color=always 'some' | \
GREP_COLOR='38;5;100' egrep -i --color=always 'string|color'
或者我们可以非常聪明并实现这个功能:
color_text_match() {
MATCHSTRING="$1"
COLOR="$2"
[[ -z "$MATCHSTRING" ]] && echo "color_text_match: No color specifies."
[[ -z "$COLOR" ]] && COLOR="214" # Default orange
GREP_COLOR="38;5;$COLOR" egrep -i --color=always "$MATCHSTRING"
}
然后:
echo "Some string to color" | \
color_text_match "Some" | \
color_text_match "string" | \
color_text_match "to" "226"