Der folgende Code gibt
[: -ge: unärer Operator erwartet
wann
i=0
if [ $i -ge 2 ]
then
#some code
fi
Warum?
Ihr Problem ergibt sich aus der Tatsache, dass $i
ein leerer Wert vorliegt, wenn Ihre Anweisung fehlschlägt. Zitieren Sie Ihre Variablen immer, wenn Sie Vergleiche durchführen, wenn die geringste Wahrscheinlichkeit besteht, dass eine davon leer ist, z.
if [ "$i" -ge 2 ] ; then
...
fi
Dies liegt daran, wie die Shell Variablen behandelt. Nehmen Sie das ursprüngliche Beispiel an,
if [ $i -ge 2 ] ; then ...
Das erste, was die Shell beim Ausführen dieser bestimmten Codezeile tut, ist das Ersetzen des Werts von $i
, genau wie es die Such- und Ersetzungsfunktion Ihres bevorzugten Editors tun würde. Nehmen wir also an, dass dies $i
leer ist oder, noch anschaulicher, dass $i
es sich um eine Reihe von Leerzeichen handelt! Die Shell wird $i
wie folgt ersetzt:
if [ -ge 2 ] ; then ...
Nachdem die Variablensubstitutionen durchgeführt wurden, fährt die Shell mit dem Vergleich fort und .... schlägt fehl, weil links von ihr nichts Verständliches zu sehen ist -gt
. Zitiert jedoch $i
:
if [ "$i" -ge 2 ] ; then ...
wird:
if [ " " -ge 2 ] ; then ...
Die Shell sieht jetzt die doppelten Anführungszeichen und weiß, dass Sie tatsächlich vier Leerzeichen mit zwei vergleichen, und überspringt das if
.
Sie haben auch die Möglichkeit, einen Standardwert für $i
if $i
wie leer anzugeben :
if [ "${i:-0}" -ge 2 ] ; then ...
Dies ersetzt den Wert 0 anstelle von $i
is $i
ist undefiniert. Ich behalte die Anführungszeichen weiterhin bei, da wiederum, wenn $i
es sich um eine Reihe von Leerzeichen handelt, diese nicht als undefiniert gelten , nicht durch 0 ersetzt werden und Sie erneut auf das Problem stoßen.
Bitte lesen Sie dies, wenn Sie Zeit haben. Die Shell wird von vielen wie eine Black Box behandelt, arbeitet jedoch mit sehr wenigen und sehr einfachen Regeln - sobald Sie wissen, was diese Regeln sind (eine davon ist, wie Variablen in der Shell funktionieren, wie oben erläutert), wird die Shell dies tun habe keine Geheimnisse mehr für dich.
Nach der Fehlermeldung zu urteilen, war der Wert von i die leere Zeichenfolge, als Sie sie ausgeführt haben, nicht 0.
quelle
Ich muss meine 5 Cent hinzufügen. Ich sehe, dass jeder
[
oder verwendet[[
, aber es ist erwähnenswert, dass sie nicht Teil der if-Syntax sind.Verwenden Sie
((...))
stattdessen für arithmetische Vergleiche .quelle
Ihr Skript funktioniert einfach großartig. Sind Sie sicher, dass Sie "i" vor dem if nichts anderes zuweisen?
Ein häufiger Fehler ist auch, nach und vor den eckigen Klammern kein Leerzeichen zu lassen.
quelle