Le code suivant donne
[: -ge: opérateur unaire attendu
quand
i=0
if [ $i -ge 2 ]
then
#some code
fi
Pourquoi?
Votre problème vient du fait qu'il $i
a une valeur vide lorsque votre déclaration échoue. Citez toujours vos variables lorsque vous effectuez des comparaisons s'il y a la moindre chance que l'une d'elles soit vide, par exemple:
if [ "$i" -ge 2 ] ; then
...
fi
Ceci est dû à la façon dont le shell traite les variables. Supposons l'exemple d'origine,
if [ $i -ge 2 ] ; then ...
La première chose que le shell fait lors de l'exécution de cette ligne de code particulière est de substituer la valeur de $i
, tout comme le ferait la fonction de recherche et de remplacement de votre éditeur préféré . Supposons donc que ce $i
soit vide ou, encore plus illustratif, que ce $i
soit un tas d'espaces! Le shell remplacera $i
comme suit:
if [ -ge 2 ] ; then ...
Maintenant que les substitutions de variables sont effectuées, le shell procède à la comparaison et ... échoue car il ne peut rien voir d'intelligible à gauche de -gt
. Cependant, citant $i
:
if [ "$i" -ge 2 ] ; then ...
devient:
if [ " " -ge 2 ] ; then ...
Le shell voit maintenant les guillemets doubles et sait que vous comparez en fait quatre espaces à 2 et ignorera le if
.
Vous avez également la possibilité de spécifier une valeur par défaut pour $i
if $i
est vide, comme suit:
if [ "${i:-0}" -ge 2 ] ; then ...
Cela remplacera la valeur 0 au lieu de $i
is $i
est indéfini. Je maintiens toujours les guillemets car, encore une fois, s'il $i
y a un tas de blancs, cela ne compte pas comme indéfini , il ne sera pas remplacé par 0 et vous rencontrerez à nouveau le problème.
Veuillez lire ceci lorsque vous en aurez le temps. Le shell est traité comme une boîte noire par beaucoup, mais il fonctionne avec très peu de règles très simples - une fois que vous savez quelles sont ces règles (l'une d'elles étant la façon dont les variables fonctionnent dans le shell, comme expliqué ci-dessus), le shell sera n’a plus de secrets pour vous.
À en juger par le message d'erreur, la valeur de i était la chaîne vide lorsque vous l'avez exécutée, et non 0.
la source
Je dois ajouter mes 5 cents. Je vois que tout le monde utilise
[
ou[[
, mais il convient de mentionner qu'ils ne font pas partie de la syntaxe if.Pour les comparaisons arithmétiques, utilisez
((...))
plutôt.la source
Votre morceau de script fonctionne très bien. Etes-vous sûr de n'attribuer rien d'autre avant le if à "i"?
Une erreur courante est également de ne pas laisser d'espace après et avant les crochets.
la source