Zdaję sobie sprawę z bibliotek w językach takich jak Ruby i JavaScript, które ułatwiają kolorowanie skryptów terminali przy użyciu nazw kolorów takich jak „czerwony”.
Ale czy jest coś takiego dla skryptów powłoki w Bash, Ksh, czy cokolwiek innego?
Zdaję sobie sprawę z bibliotek w językach takich jak Ruby i JavaScript, które ułatwiają kolorowanie skryptów terminali przy użyciu nazw kolorów takich jak „czerwony”.
Ale czy jest coś takiego dla skryptów powłoki w Bash, Ksh, czy cokolwiek innego?
Odpowiedzi:
Możesz zdefiniować kolory w swoich skryptach bash w następujący sposób:
red=$'\e[1;31m'
grn=$'\e[1;32m'
yel=$'\e[1;33m'
blu=$'\e[1;34m'
mag=$'\e[1;35m'
cyn=$'\e[1;36m'
end=$'\e[0m'
A następnie użyj ich do wydrukowania w wymaganych kolorach:
printf "%s\n" "Text in ${red}red${end}, white and ${blu}blue${end}."
Możesz użyć tput
ORprintf
Za pomocą tput
,
po prostu utwórz funkcję jak poniżej i użyj ich
shw_grey () {
echo $(tput bold)$(tput setaf 0) $@ $(tput sgr 0)
}
shw_norm () {
echo $(tput bold)$(tput setaf 9) $@ $(tput sgr 0)
}
shw_info () {
echo $(tput bold)$(tput setaf 4) $@ $(tput sgr 0)
}
shw_warn () {
echo $(tput bold)$(tput setaf 2) $@ $(tput sgr 0)
}
shw_err () {
echo $(tput bold)$(tput setaf 1) $@ $(tput sgr 0)
}
możesz wywołać powyższą funkcję za pomocą shw_err "WARNING:: Error bla bla"
Za pomocą printf
print red; echo -e "\e[31mfoo\e[m"
echo -e
nie jest printf
, a także potrzebuje ostrzeżenia, że różni się od tput
opcji tym, że nie dostosowuje się automatycznie do koloru $TERM
.
W Zsh :
autoload -U colors
colors
echo $fg[green]YES$fg[default] or $fg[red]NO$fg[default]?
print -P '%F{red}blah%f'
Do prostych typowych zastosowań (pełny wiersz tekstu tylko w jednym kolorze, z końcowym znakiem nowej linii) zmodyfikowałem kod jasonwryan w następujący sposób:
#!/bin/bash
red='\e[1;31m%s\e[0m\n'
green='\e[1;32m%s\e[0m\n'
yellow='\e[1;33m%s\e[0m\n'
blue='\e[1;34m%s\e[0m\n'
magenta='\e[1;35m%s\e[0m\n'
cyan='\e[1;36m%s\e[0m\n'
printf "$green" "This is a test in green"
printf "$red" "This is a test in red"
printf "$yellow" "This is a test in yellow"
printf "$blue" "This is a test in blue"
printf "$magenta" "This is a test in magenta"
printf "$cyan" "This is a test in cyan"
awk -v red="$(printf '\e[1;31m%%s\e[0m\\n')" -v green="$(printf '\e[1;32m%%s\e[0m\\n')" 'BEGIN { printf red, "This text is in red"; printf green, "This text is in green" }'
Lepiej jest użyć, tput
który będzie obsługiwał znaki specjalne w zależności od możliwości wyjścia / terminala. (Jeśli terminal nie może zinterpretować \e[*
kodów kolorów, zostanie „zanieczyszczony”, co utrudni odczytanie danych wyjściowych. (Lub czasami, jeśli grep
takie dane wyjściowe, zobaczysz je \e[*
w wynikach)
Zobacz ten samouczek dlatput
.
Możesz pisać :
blue=$( tput setaf 4 ) ;
normal=$( tput sgr0 ) ;
echo "hello ${blue}blue world${normal}" ;
Oto samouczek drukowania kolorowego zegara w terminalu.
Zauważ również, że tput
nadal może wypisywać znak zmiany znaczenia podczas przekierowywania STDOUT do pliku:
$ myColoredScript.sh > output.log ;
# Problem: output.log will contain things like "^[(B^[[m"
Aby temu zapobiec, skonfiguruj tput
zmienne zgodnie z proponowanym rozwiązaniem .