case
é apenas para correspondência de padrões, não fará avaliação aritmética (exceto, talvez, se você considerar zsh
<x-y>
extended matching operator). O [...]
é apenas para corresponder a um caractere (ou elemento de agrupamento em algumas implementações) com base no conjunto especificado dentro. Portanto, por exemplo, [0-80]
corresponderia a um caractere se for um dos 0
a 8
ou 0
(ou seja, um dos 0, 1, 2, 3, 4, 5, 6, 7, 8).
Você pode corresponder números com padrões como:
case $(($number)) in
([0-9]|[1-7][0-9]|80) echo ">=0<=80";;
(8[1-9]|9[0-9]|100) echo ">=81<=100";;
... and so on
esac
Mas você pode ver facilmente que não é a ferramenta certa.
O caractere [...]
corresponde a um na lista de caracteres especificados, portanto, [121-300]
corresponde a qualquer caractere que seja 1, 2, 1 a 3, 0 ou 0, por isso é o igual a [0-3]
ou [0123]
.
Uso:
if [ "$number" -ge 0 ] && [ "$number" -le 80 ]; then
echo ">=0<=80"
elif [ "$number" -ge 81 ] && [ "$number" -le 100 ]; then
echo ">=81<=100"
elif ... and so on
...
fi
Outra maneira de usar case
seria como:
case $((
(number >= 0 && number <= 80) * 1 +
(number > 80 && number <= 100) * 2 +
(number > 100 && number <= 120) * 3 +
(number > 120 && number <= 300) * 4)) in
(1) echo ">=0<=80";;
(2) echo ">=81<=100";;
(3) echo ">=101<=120";;
(4) echo ">=121<=300";;
(0) echo "None of the above";;
esac
Ou use o operador ternário ( x ? y : z
):
case $((
number >= 0 && number <= 80 ? 1 :
number > 80 && number <= 100 ? 2 :
number > 100 && number <= 120 ? 3 :
number > 120 && number <= 300 ? 4 : 0)) in...
Ou, como @mikeserv, pense fora da caixa, inverta a lógica case
e corresponda 1
ao valor dessas aritméticas comparações .