logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

Vous n'êtes pas identifié(e).


L'icône rouge permet de télécharger chaque page du wiki visitée au format PDF et la grise au format ODT → ODT PDF Export

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
Prochaine révision Les deux révisions suivantes
doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique [31/05/2014 17:46]
Hypathie [1) opérateurs booléens de comparaison de nombres]
doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique [20/02/2023 21:31]
agp91 [Conclusion sur les opérateurs lexicographiques et les opérateurs de comparaison numérique]
Ligne 2: Ligne 2:
  
   * Objet : suite de la série de wiki visant à maîtriser bash via les différents caractère spéciaux.   * Objet : suite de la série de wiki visant à maîtriser bash via les différents caractère spéciaux.
-  * Niveau requis : {{tag>​débutant}} +  * Niveau requis : {{tag>​débutant ​avisé}} 
-  * Commentaires : //Contexte d'​utilisation du sujet du tuto. // +  * Commentaires : FIXME 
   * Débutant, à savoir : [[:​doc:​systeme:​commandes:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !.]] :-)   * Débutant, à savoir : [[:​doc:​systeme:​commandes:​le_debianiste_qui_papillonne|Utiliser GNU/Linux en ligne de commande, tout commence là !.]] :-)
-  * Suivi : {{à-placer}} ​ +  * Suivi :  
-    * Création par **Hypathie** 08/​04/​2014 +    * Création par [[user>Hypathie]] le 08/​04/​2014 
-    * Testé par <Hypathie> le <Avril 2014> +    * Testé par [[user>Hypathie]] en Avril 2014 
-  * Commentaires sur le forum : [[https://​debian-facile.org/​viewtopic.php?​pid=87499#p87499 ​| Lien vers le forum concernant ce tuto]] ((N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !))+  * Commentaires sur le forum : [[https://​debian-facile.org/​viewtopic.php?​pid=140771#p140771 ​| Lien vers le forum concernant ce tuto]] ((N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !))
  
-**RAPPEL DU PLAN DE LA SÉRIE ​: **\\+**Nota :** Contributeurs,​ les FIXME sont là pour vous aider, supprimez-les une fois le problème corrigé ou le champ rempli !
  
-1) Intro I :  [[atelier:​chantier:​bash-les-differents-caracteres-speciaux|Bash : Introduction]]\\ ​ 
  
-2) chap II : [[atelier:chantier:​la-page-man-bash-les-caracteres-speciaux|Bash : Détail et caractères]]\\ +  * [[doc:programmation:​shells:​bash-les-differents-caracteres-speciaux|Vision d'​ensemble]] 
 +  * [[doc:programmation:​shells:​la-page-man-bash-les-caracteres-speciaux|Détail et caractères]] 
 +  * [[doc:​programmation:​shells:​la-page-man-bash-ii-les-operateurs-lexicographiques|Les opérateurs lexicographiques]] 
 +  * ;-) 
 +  * [[doc:​programmation:​shells:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques|Les symboles dans les calculs]] 
 +  * [[doc:​programmation:​shells:​page-man-bash-v-les-tableaux|Les tableaux]] 
 +  * [[doc:​programmation:​shells:​man-bash-vi-les-caracteres-de-transformation-de-parametres|Les caractères de transformation de parametres]] 
 +  * [[doc:​programmation:​shells:​bash-vii-globs-etendus-regex|Bash : Variables, globs étendus, ERb, ERe]]
  
-3) chap III : [[atelier:​chantier:​la-page-man-bash-ii-les-operateurs-lexicographiques|Bash : les opérateurs lexicographiques]]\\ ​+===== Introduction =====
  
-4) chap IV : C'est ici !\\ +<​note>​ 
 +Dans la page du manuel de bash, **les opérateurs des commandes de test** sont nommées __**primitives**__. 
 +</​note>​
  
-5) chap V : [[atelier:​chantier:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques|Bash : les symboles dans les calculs]]\\ ​+Bash dispose de plusieurs commandes pour **réaliser des comparaisons numérique**.
  
-6) chap VI : [[atelier:​chantier:​page-man-bash-v-les-tableaux|Bash ​les tableaux]]\\ ​+  * Les commandes de test : 
 +    * Les commandes internes **[** et **test**. 
 +    * Et la commande composée **<​nowiki>​[[</​nowiki>​**. 
 +  * Les commandes d'​évaluation numériques ​: 
 +    * La commande composée **<​nowiki>​((</​nowiki>​** et la commande interne **let**.
  
-7) chap VII : [[atelier:chantier:​man-bash-vi-les-caracteres-de-transformation-de-parametres|Bash : les caractères de transformation de parametres]]\\ ​+<​note>​ 
 +  * Les commandes **<​nowiki>​((</​nowiki>​** et **let** sont équivalentes. 
 +  * Les commandes **[** et **test** sont équivalentes. 
 +  * Les commandes **[** et **test** sont disponibles dans leurs versions externe ​**/​usr/​bin/​[** et **/​usr/​bin/​test**. 
 +    * Elles ont toutes ​les deux la même page de manuel (**man [** ou **man test**). 
 +  * Les commandes internes disposent ​de primitive que n'ont pas les commandes externes. 
 +</​note>​
  
-8) chap VIII [[atelier:​chantier:​bash-vii-globs-etendus-regex|Bash : globs étendus et regex]] +<​note>​ 
-Contributeurs,​ les FIXME sont là pour vous aider, supprimez-les une fois le problème corrigé ou le champ rempli !+__Rappels ​:__
  
-=====1) opérateurs booléens ​de comparaison ​de nombres ===== +  *  Une commande de test renvoie le code de retour 0 (considérer comme vrai) lorsque le test réussi et (considérer comme fauxlorsqu'​il échoue. 
-Comme aux chapitre précédent on retrouve les opérateurs ​de comparaison booléens de comparaison (== != , < , > , >=, <= , ! )\\ +  *  Le code retour d'une commande est mémorisé dans le paramètre spécial $?. 
-et des caractères ​de comparaisons relatifs aux commandes de tests.+  *  L'​opérateur ​de contrôle **&&​** exécute la commande suivante, si la commande précédente à renvoyée un code de retour égale à 0. 
 +  ​* ​ L'​opérateur ​de contrôle **||** exécute la commande suivantesi la commande précédente à renvoyée un code de retour supérieur à 0. 
 +</​note>​
  
-^ Opérateur ^ Description ​                          ^ +===== Comparaison ​numérique avec [ et [[ =====
-| ** **        | **initialisation d'une constante ​numérique** (ne pas confondre ​avec = de l'​affectation de variable qui n'a pas d'​espace autour de lui) | +
-| ** == **    | **Comparaison d'un égalité** ​             | +
-| !         | Comparaison d'une différence ​         | +
-| >         | Comparaison de plus grand que         | +
-| >         | Comparaison de plus grand ou égal que | +
-| <         | Comparaison de plus petit que         | +
-| <=         | Comparaison de plus petit ou égal que |+
  
-  * syntaxe :+Les commandes de test dispose de 6 primitives binaires pour effectuer des comparaisons numériques.
  
-<​code>​ +==== Syntaxe ====
-(( a 23 ))  # Initialiser une valeur, style C, avec des espaces des deux +
-              # côtés du signe "=".+
  
-(("​$a" ​"​$b"​))+  * **test expr1 OP expr2** 
 +  * **[ expr1 OP expr2 ]** 
 +  * **<nowiki>​[[</​nowiki>​ expr1 OP <​nowiki>​expr2</​nowiki>​ ]]**
  
-(("​$a" ​<= "​$b"​))+  * Avec : 
 +    * **Expr1** et **expr2** sont sujets au développement des paramètres. 
 +    * Avec la commande **<nowiki>​[[</​nowiki>​**,​ **expr1** et **expr2** sont sujets à l’évaluation arithmétique. Les commandes **[** ou **test**, ne le permettent pas. 
 +    * **OP**, l'une des primitives du tableau suivant.
  
-(("​$a"​ > "​$b"​)) +|  Liste des primitives de comparaison numérique ​ || 
-</​code>​ +^Primitives ^ Retours ^ 
-<​note>​ +|''​-eq ''​ | est égal à | 
-Attention on ne vérifie pas si deux nombres sont égaux avec les doubles parenthèses car cela n'est pas une comparaison ! +|''​-ne ''​ | ​n'est pas égal à | 
-</​note>​ +|''​-gt ''​ | est plus grand que | 
-  * **exemple dans le terminal:** +|''​-ge ''​ |est plus grand ou égal à | 
-<​code=user>​ +|''​-lt ''​ |est plus petit que | 
-(( nombre1 = 12 )) +|''​-le ''​ |est plus petit ou égal à | 
-#puis + 
-(( nombre2 ​13 )) +==== Exemples ==== 
-#puis + 
-(( "​$nombre1" ​"​$nombre2"​ )) +<code user
-#puis+[ 25 -eq 20 ] Teste si 25 est égale à 20
 echo $? echo $?
 +</​code><​code>​
 +
 </​code>​ </​code>​
-retour ​+ 
-<​code>​ +<code user> 
-1+var1=17 
 +var2=18 
 +echo "$var1 est-il plus grand que $var2 $([ $var1 -gt $var2 ]; echo $?)" 
 +echo "$var1 est-il plus petit que $var2 : $([[ $var1 -lt $var2 ]]; echo $?)" 
 +echo "$var1 est-il différent de $var2 : $(test $var1 -ne $var2 ; echo $?)" 
 + 
 +unset var1 var2 
 +</​code>​<​code>​ 
 +17 est-il plus grand que 18 : 1 
 +17 est-il plus petit que 18 : 0 
 +17 est-il différent de 18 : 0
 </​code>​ </​code>​
-  * **exemple avec le script "mon-script":​** + 
-<code bash>+Copions ​le code ci-dessous dans le fichier ​**mon_script**.\\  
 +Puis exécutons le avant de le supprimer. 
 + 
 +<code bash mon_script>
 #!/bin/bash #!/bin/bash
-a=23 ; b=2 +a=; b=1 
-if (( "​$a" ​"​$b" ​)) ; then +if "​$a" ​-gt "​$b" ​; then 
-  echo " "+ echo "$a est plus grand que $b"
 fi fi
-echo "$a n'est pas inférieur à $b" 
  
-</​code>​+if test 100 -gt 99 
 +then 
 + echo "​vrai" ​  #​réponse : vrai 
 +else 
 + echo "​faux"​ 
 +fi     
 +</​code>​<code user> 
 +bash mon_script
  
-**Remarquez bien le retour de : **+rm -f mon_script 
 +</​code><​file>​ 
 +2 est plus grand que 1 
 +vrai 
 +'​mon_script'​ supprimé 
 +</​file>​
  
-<code=user> +==== Particularités de la commande [[ ==== 
-./mon-script ​; echo $?+ 
 +Seule la commande **<​nowiki>​[[</​nowiki>​** permet de tester une expression arithmétique. 
 + 
 +<code user> 
 +test 21+21 -eq 42 ; echo -e $?\\n 
 + 
 +[ 21*2 -eq 42 ] ; echo -e $?\\n 
 + 
 +[[ 84-42 -eq 42 ]] ; echo $? 
 +</​code><​code>​ 
 +bash: test: 21+21 : nombre entier attendu comme expression 
 +
 + 
 +bash: [: 21*2 : nombre entier attendu comme expression 
 +
 + 
 +0
 </​code>​ </​code>​
 +<​note>​
 +Lorsqu'​une commande interne **le code de retour renvoie 2**, cela signifie un mauvais usage de cette commande.
 +</​note>​
  
-retour :+Elle est aussi la seule à accepter les chaînes vides qui sont alors évaluées à **0**.
  
-<​code>​ +<​code ​user
-23 n'est pas inférieur à 2+[[ 0 -eq ""​ ]] ; echo $? 
 +[[ ""​ -ne 0 ]] ; echo $? 
 +[[ ""​ -eq ""​ ]] ; echo $? 
 +</​code><​code>​ 
 +
 +1
 0 0
 </​code>​ </​code>​
-**le code de retour est celui de l'​exécution de la dernière commande (echo) du script !** 
-(__Voir l'​utilisation de la commande exit dans les script__) 
  
 +Idem pour les chaînes de caractères sans espace (mots). Un mot est substitué par **0**.
 +
 +<code user>
 +[[ mot -eq 0 ]] ; echo $?
 +[[ 0 -ne mot ]] ; echo $?
 +[[ mot1 -eq mot2 ]] ; echo $?
 +</​code><​code>​
 +0
 +1
 +0
 +</​code>​
  
 <note important>​ <note important>​
-**ATTENTION à la confusion avec les tests sur les chaînes de caractères !** +Attention : 
-<code bash> +<code bash mon_script
-a=23 +#​!/​bin/​bash 
-b=2 +var1=8 
-if (( "$a" ​"$b" ​)) ; then +var2=7 
- echo "$a > $b"+if test "$e" ​-gt "$f" ; then 
 +  echo " $var1 est plus grand que $var2 "
 fi fi
-echo " "+printf \\n 
 +test 8 -gt 7 && ​echo "$var1 est plus grand que $var2" 
 +</​code>​
  
-c="​23"​ +<code user
-d="​24"​ +bash mon_script
-if test "​$a" ​"​$b"​ ; then +
-  echo "​Attention ! incohérence "​$c"​ > "​$d"​ car avec test et crochets,  +
-        il doit s'agir de chaînes de caractères."​ +
-fi +
-echo " "+
  
-e="​26"​ +rm -v mon_script
-f="​25"​ +
-if [ "​$a"​ > "​$b"​ ] ; then  +
-  echo "De même, Attention ! incohérence "​$e"​ > "​$f"​ car avec test et crochets,  +
-         il s'agit exclusivement de chaînes de caractères."​ +
-fi +
-</​code>​ +
-Retour: ​ 8-+
-<​code>​ +
-23 > 2 +
-  +
-Attention ! incohérence 23 > 24 car avec test et crochets,  +
-             il s'agit exclusivement de chaînes de caractères. +
-  +
-De même, Attention ! incohérence 26 > 25 car avec test et crochets,  +
-             il s'agit exclusivement de chaînes de caractères.+
 </​code>​ </​code>​
 +<file config retour de la commande>​
 +mon_script: ligne 4 : test:  : nombre entier attendu comme expression
 +
 +8 est plus grand que 7 
 +'​mon_script'​ supprimé
 +</​file>​
 </​note>​ </​note>​
  
-=====2) Opérateurs de comparaison de nombres avec la commande test ou les crochets===== +==== Mauvais usages ​====
-(pour comparer des nombres comme avec les booléens, mais avec la commande test ou crochets)+
  
 +Le caractère **$** est obligatoire pour développer les paramètres. Sans, ils sont interprétés comme des mots.
  
-^Caractère ​  ​^ ​                         ^ +Avec la commande **[** (ou **test**), les chaînes vides ou les mots sont à proscrire.
-|-eq         | est égal à               | +
-|-ne         | n'est pas égal à         | +
-|-gt         | est plus grand que       | +
-|-ge         |est plus grand ou égal à  | +
-|-lt         |est plus petit que        | +
-|-le         |est plus petit ou égal à  |+
  
-        +<code user> 
-===Syntaxe avec les crochets ​:===+test 42 -eq ""​ ; echo $? 
 +[ 42 -lt ""​ ] ; echo $? 
 +echo ===== 
 +test ""​ -gt 42 ; echo $? 
 +[ ""​ -ge 42 ] ; echo $? 
 +</​code><​code>​ 
 +bashtest:  : nombre entier attendu comme expression 
 +
 +bash: [:  : nombre entier attendu comme expression 
 +
 +===== 
 +bash: test:  : nombre entier attendu comme expression 
 +
 +bash: [:  : nombre entier attendu comme expression 
 +
 +</​code>​
  
-<​code> ​      +<​code ​user
-[ "​$a" ​-eq "$b" ] +test mot -eq 0 ; echo $? 
-"​$a" ​-ne "$b" ] +-eq mot ] ; echo $? 
-["​$a" ​-gt "$b" ]  +test O -le 0 ; echo $? 
-[ "$a" -ge "$b" ] +[ "mot" -ge 0 ] ; echo $? 
-[ "$a" -lt "​$b"​ ] +echo $
-"​$a"​ -le "​$b"​ ]+</​code><​code>​ 
 +bash: test: mot : nombre entier attendu comme expression 
 +
 +bash: [: mot : nombre entier attendu comme expression 
 +
 +bash: test: O : nombre entier attendu comme expression 
 +
 +bash: [: mot : nombre entier attendu comme expression 
 +2
 </​code>​ </​code>​
  
-===Syntaxe avec la commande ​test :===+Avec **[** (ou **test**) et **<​nowiki>​[[</​nowiki>​**,​ les opérandes ne peuvent être des chaînes de caractères qui comportent des espaces.
  
-<​code>​ +<​code ​user
-test "$a" -eq "$b" +test "Du texte" -eq 0 ; echo $? 
-test "​$a" ​-ne "$b" +[ 0 -ge "Du texte" ​] ; echo $? 
-test "$a" -gt "​$b"​ +[[ "Du texte" -ge 0 ]] ; echo $? 
-test "$a" -ge "$b" +</​code><​code>​ 
-test "​$a"​ -lt "​$b"​ +bash: test: Du texte : nombre entier attendu comme expression 
-test "​$a"​ -le "​$b"​+
 +bash: [: Du texte : nombre entier attendu comme expression 
 +
 +bash: [[: Du texte : erreur de syntaxe dans l'​expression (le symbole erroné est « texte ») 
 +1
 </​code>​ </​code>​
  
-===Exemple avec crochets dans le terminal :===+<note > 
 +Il est remarquable que le test ''<​nowiki>​[[ "Du texte" -ge 0 ]]</​nowiki>'',​ ne renvoie pas le **code de retour 2**.\\  
 +Pourtant il s'agit bien d'un mauvais usage de la commande ''<​nowiki>​[[</​nowiki>''​. 
 +</​note>​ 
 + 
 +Les deux opérandes sont obligatoires. 
 <code user> <code user>
-[ 25 -eq 20 +test 42 -eq ; echo $? 
-#puis+[ 42 -lt ; echo $? 
 +[[ 42 -ne ]] 
 +echo $? 
 +echo ===== 
 +test -gt 42 ; echo $? 
 +[ -ge 42 ] ; echo $? 
 +[[ -le 42 ]]
 echo $? echo $?
 +</​code><​code>​
 +bash: test: 42 : opérateur unaire attendu
 +2
 +bash: [: 42 : opérateur unaire attendu
 +2
 +bash: argument « ]] » inattendu pour l'​opérateur binaire conditionnel
 +bash: erreur de syntaxe près de « ]] »
 +2
 +=====
 +bash: test: -gt : opérateur unaire attendu
 +2
 +bash: [: -ge : opérateur unaire attendu
 +2
 +bash: opérateur binaire conditionnel attendu
 +bash: erreur de syntaxe près de « 42 »
 +2
 </​code>​ </​code>​
-retour : + 
-<​code>​ +Ainsi que les espaces.\\ ​ 
- +Lorsqu'​il n'y pas d'​espaces entre les opérandes et l'​opérateur,​ l'​ensemble est considéré comme une chaîne de caractères\\ ​ 
-</​code>​ +Puisque la chaîne est non vide, le test n'​échoue pas. 
-**ou encore dans le terminal :**+
 <code user> <code user>
-var1=17 +test 420-ne420 ; echo $? 
-var2=18 +420-gt42 ] ; echo $? 
-"​$var1" ​-gt "​$var2" ​+[[ 42-lt420 ]] ; echo $? 
-echo $?+</​code><​code>​ 
 +
 +
 +0
 </​code>​ </​code>​
-**OU mieux :**+ 
 +Ne pas utiliser les opérateurs ​**<** et **>** avec **[** (ou **test**) et **<​nowiki>​[[</​nowiki>​** pour réaliser des comparaisons numériques.\\  
 +Car avec ces commandes, ces opérateur sont des opérateurs de comparaison lexicographique.\\  
 +(voir [[https://​debian-facile.org/​doc:​programmation:​shells:​la-page-man-bash-ii-les-operateurs-lexicographiques|Bash : Les opérateurs sur chaînes]]). 
 + 
 +__Rappel :__ Avec **[** (ou **test**), les opérateurs **<** et **>** s'​utilisent protégés (voir [[https://​debian-facile.org/​atelier:​chantier:​bash-comparaison-lexicographique-des-chaines#​tests-avec1|Bash,​ comparaison lexicographique avec [ ou test]]).
 <code user> <code user>
-test 100 -gt 99 && ​echo "​vrai"​ || echo "​faux" ​ # retour : vrai+test 425 \> 4242 ; echo $? 
 +[ 426 \> 4242 ] ; echo $? 
 +[[ 4242 < 427 ]] ; echo $?
 </​code>​ </​code>​
-<code=user+<file config retour des commandes>​ 
-test 100 -lt 99 && echo "vrai" || echo "faux" ​  # retour : faux+
 +
 +
 +</​file>​ 
 + 
 +Lexicographiquement 425, 426 et 427 sont supérieurs (placés après dans l'​ordre lexicographique),​ mais sont inférieurs (plus petits) numériquement à 4242. 
 + 
 +===== Comparaison numérique avec (( ===== 
 + 
 +Syntaxe : 
 +<code
 +let <​expr1><​OP><​expr2>​ 
 +let "<​expr1>​ <OP> <​expr2>​" 
 +(( <​expr1>​ <OP> <​expr2>​ )) 
 + 
 +<​expr1>​ et <​expr2>​ sont sujets au développement des paramètres et à l’évaluation arithmétique. 
 +Avec <OP> l'un des opérateurs donnés dans le tableau suivant.
 </​code>​ </​code>​
  
-MAIS +__Remarques :__ Les commandes **let** et **<​nowiki>​((</​nowiki>​** sont équivalentes. 
 + 
 +|  Opérateurs de comparaison numérique des commandes let et <​nowiki>​((</​nowiki> ​ || 
 +^ Opérateurs ^ Description ^ 
 +| ''​ == ''​ | Comparaison d'une égalité ​             | 
 +| ''​ != ''​ | Comparaison d'une différence ​         | 
 +| ''​ > ''​ | Comparaison de plus grand que         | 
 +| '' ​ >= ''​ | Comparaison de plus grand ou égal que | 
 +| ''​ < ''​ | Comparaison de plus petit que         | 
 +| ''<​nowiki><​=</​nowiki>​ ''​ | Comparaison de plus petit ou égal que | 
 + 
 + 
 +La commande **let** ne supporte qu'un seul argument.\\  
 +Si l'​expression arithmétique à évaluer comporte des espaces, l'​expression doit être protégée par des guillemets simples ou doubles.\\  
 +Si l'​expression n'est pas protégée, les opérateurs commençant par **<** ou **>** doivent être protégés\\  
 +(Voir plus bas : [[https://​debian-facile.org/​doc:​programmation:​shells:​page-man-bash-iii-les-operateurs-de-comparaison-numerique#​mauvais-usages|Mauvais usages]].) 
 + 
 +==== Exemples dans le terminal ====
  
 <code user> <code user>
-[ "​LEbash" ​"​Labash"​ ]; echo $?  #réponse 1 car l'​expression ​est fausse+(( 42 == 42 )) # Est-ce que 42 est égale à 42. 
 +echo $? Affiche le code de retour. 
 +let 24\>​=24 #​ Est-ce que 24 est supérieur ou égale à 24 
 +echo $? # Affiche le code de retour.
 </​code>​ </​code>​
 +<file config retour des commandes>​
 +0
 +0
 +</​file>​
  
 <code user> <code user>
-[ 5 -eq 5 ]; echo $?  réponse : 0  car l'​expression ​est vraie+nombre1=12 
 +nombre2=13 
 +(( $nombre1 > $nombre2 )) # Est-ce-que nombre1 (12) est strictement supérieur au nombre2 (13). 
 +echo $? Affiche le code de retour. 
 +let "​$nombre1 != $nombre2"​ #​Est-ce-que nombre1 (12) est différent du nombre2 (13) 
 +echo $? # Affiche le code de retour. 
 + 
 +unset nombre1 nombre2 # Suppression des paramètres nombre1 et nombre2
 </​code>​ </​code>​
-=== Exemple avec la commande test dans le terminal:​===+<file config retour des commandes>​ 
 +
 +
 +</​file>​ 
 + 
 +Les paramètres peuvent être transmis sans **$** (Sauf les paramètres positionnels et les paramètres spéciaux). 
 <code user> <code user>
-test 17 -gt 11 ; echo $?+n1=42 
 +n2=24 
 +(( n1 > n2 )) && ​echo "$n1 > $n2" || echo "$n1 < $n2" 
 +let n1==n2 && echo "$n1 est égale à $n2" || echo "$n1 est différent de $n2" 
 + 
 +unset n1 n2
 </​code>​ </​code>​
-retour: +<file config ​retour ​des commandes>​ 
-<​code>​ +42 > 24 
 +42 est différent de 24 
 +</​file>​ 
 +  
 +Comme nous l'​avons vu au dessus, les paramètres n'ont pas besoin du caractère **$** pour être développés.\\  
 +Un simple mot sera alors interprété comme un paramètre.\\  
 +Si ce paramètre n'​existe pas, le mot sera substitué par **0**. 
 + 
 +<​code ​user
 +(("​mot"​ == 0)) 
 +echo '​(("​mot"​ == 0)) revoie le code de retour'​ $? 
 +let "mot <= 0" 
 +echo 'let "mot <= 0" revoie le code de retour'​ $? 
 + 
 +n="​mot"​ 
 +((n!=0)) 
 +echo -e "Avec n=\"​$n\"​ ; ((n!=0)) renvoie le code de retour $?" 
 +let n==0 
 +echo -e "Avec n=\"​${n}\"​ ; let n==0 renvoie le code de retour $?" 
 + 
 +unset n
 </​code>​ </​code>​
-De même :+<file config retour des commandes>​ 
 +(("​mot"​ == 0)) revoie le code de retour 0 
 +let "mot <= 0" revoie le code de retour 0 
 +Avec n="​mot"​ ; ((n!=0)) renvoie le code de retour 1 
 +Avec n="​mot"​ ; let n==0 renvoie le code de retour 0 
 +</​file>​ 
 + 
 +Si un paramètre existe mais que sa valeur est vide, son développement retournera 0.
 <code user> <code user>
-var1=17 ; var2=11 test "$var1" -gt "​$var2" ​; echo $?+n= 
 +((n==0)) echo $
 +let 'n != 0' ; echo $? 
 + 
 +unset n
 </​code>​ </​code>​
-retour : +<file config retour des commandes>
-<code>+
 0 0
-</code+
-===Exemple avec les crochets dans un script:=== +</file
-<​code ​bash+Avec la commande **<​nowiki>​((</​nowiki>​**, ​les espaces ne sont pas obligatoires. 
-#!/bin/bash +<​code ​user
-a=2 ; b=1 +n1=4242 
-if "$a" -gt "$b" ​] ; then +n2=2424 
-        echo "$est plus grand que $b"+if ((n1>​n2)) 
 +then 
 + echo "$n1 est supérieur à $n2
 +else 
 + echo "$n1 est inférieur à $n2"
 fi fi
 +
 +unset n1 n2
 </​code>​ </​code>​
-retour de ./mon-script :+<file config ​retour de la commande>​ 
 +4242 est supérieur à 2424 
 +</file>
  
-<​code>​ +==== Mauvais usages ==== 
-2 est plus grand que 1+ 
 +Avec la commande **let**, si l'​expression à évaluer n'est pas protégée,​\\  
 +Les espaces entre les opérandes et l'​opérateur ne sont pas supportés. 
 + 
 +<​code ​user
 +let -42 \< 0 ; echo $? 
 +let 0 == 0 ; echo $?
 </​code>​ </​code>​
 +<file config retour des commandes>​
 +bash: let: < : erreur de syntaxe : opérande attendu (le symbole erroné est « <​ »)
 +1
 +bash: let: == : erreur de syntaxe : opérande attendu (le symbole erroné est « == »)
 +1
 +</​file>​
  
-===Exemple avec la commande test dans un script:=== 
  
-<​code ​bash+Avec la commande **let**, si l'​expression à évaluer est protégé par des guillemets simples,\\  
-if test 100 -gt 99 +Les paramètres sont développés uniquement s'ils ne disposent pas du caractère **$**.\\  
-then +S'il est fourni, une erreur est renvoyée. 
- echo "​vrai" ​  #​réponse : vrai + 
-else +<​code ​user
- echo "​faux"​ +n=42 
-fi+let '​n==42'​ ; ​echo $? 
 +let '$n > 42'​ ; ​echo $?
 </​code>​ </​code>​
-retour de ./mon-script+<file config ​retour ​des commandes>​ 
 +
 +bash: let: $n == 42 : erreur ​de syntaxe : opérande attendu (le symbole erroné est « $n == 42 ») 
 +
 +</​file>​ 
 + 
 +Avec la commande **let**, si l'​expression à évaluer n'est pas protégée, les opérateurs **<**, **<​nowiki><​=</​nowiki>​**,​ **>** et **>=** doivent être protégés.\\ 
 +Les trois types de protection (**\**, entre guillemets simples **<​nowiki>''<​/nowiki>​** et entre guillemets doubles **""​** fonctionnent.\\  
 +S'ils ne sont pas protégés, les opérateurs **<** et **>** sont des opérateurs de redirection.\\  
 +Démonstration : 
 + 
 +__Rappels :__\\  
 +La commande **printf "​\n"​**,​ renvoit un saut de ligne.\\  
 +La commande **echo ​-n**, n'​ajoute pas de saut ligne à la fin de son retour. 
 + 
 +<code user> 
 +p=$PWD 
 +mkdir /​tmp/​test_let 
 +cd /​tmp/​test_let 
 + 
 +let 240>​420 ;​ echo $? 
 +let 241>​=421 ;​ echo $? 
 +let 243<​423 ;​ echo $? 
 +let 244<​=424 ;​ echo $? 
 + 
 +printf "​\n"​ 
 +echo -n "ls :" 
 +ls 
 +printf "​\n"​ 
 + 
 +cd $p 
 +rm -rfv /​tmp/​test_let 
 +</​code>​ 
 +<file config retour des commandes>​ 
 +bash: let: une expression est attendue 
 +
 +bash: let: une expression est attendue 
 +
 +bash: 423: Aucun fichier ou dossier de ce type 
 +
 +bash: =424: Aucun fichier ou dossier de ce type 
 +
 + 
 +ls : 420  '​=421'​ 
 + 
 +'/​tmp/​test_let/​=421'​ supprimé 
 +'/​tmp/​test_let/​420'​ supprimé 
 +répertoire '/​tmp/​test_let'​ supprimé 
 +</​file>​ 
 + 
 +Les opérateurs **>** et **>=** ont créé respectivement les fichiers **420** et **=421**.\\ 
 +Les opérateurs **<** et **<​nowiki><​=</​nowiki>​** ont recherché les fichiers **423** et **=424**, sans les trouver. 
 + 
 +Les opérateurs de comparaison sont des opérateurs binaires, ils attendent donc 2 arguments (ou opérandes).\\ 
 +Les commande **<​nowiki>​((</​nowiki>​** et **let** retournent une erreur s'il manque un opérande.
 <​code>​ <​code>​
-vrai+(( == 0)) ; echo $? 
 +let 0>= ; echo $? 
 +echo ===== 
 +(( 42 < ""​)) ;​ echo $? 
 +let ""​!=24 ;​ echo $?
 </​code>​ </​code>​
 +<file config retour des commandes>​
 +bash: ((: == 0 : erreur de syntaxe : opérande attendu (le symbole erroné est « == 0 »)
 +1
 +bash: let: une expression est attendue
 +1
 +=====
 +bash: ((: 42 <  : erreur de syntaxe : opérande attendu (le symbole erroné est « <  »)
 +1
 +bash: let: !=24 : erreur de syntaxe : opérande attendu (le symbole erroné est « !=24 »)
 +1
 +</​file>​
  
-<note important+Les opérandes ne peuvent être des chaînes de caractères contenant des espaces. 
-ATTENTION ​+ 
-<code bash>+__Rappel :__ L'​option **-e** de la commande **echo** permet de développer les caractères protégés, (ici **\n** qui se développe en saut de ligne).\\  
 +Le développement des caractères protégés se réalisent entre guillemets doubles.\\  
 +Sans guillemets, il est nécessaire de protéger le caractère de protection (**\\n**). 
 + 
 +<code user
 +(("Du texte" >= 0)) 
 +echo -e '* (("Du texte" >= 0)) renvoie le code de retour'​ $?\\n 
 +let 424\>"​Du texte"​ 
 +echo -e '* let 424\>"​Du texte" renvoie le code de retour'​ $?\\n 
 + 
 +n="Du texte"​ 
 +((0<​=n)) 
 +echo -e "* Avec n=\"​$n\"​ ; ((0<=n)) renvoie le code retour $?​\n"​ 
 +let n==0 
 +echo "* Avec n=\"​${n}\"​ ; let n==0 renvoie le code retour $?" 
 + 
 +unset n 
 +</​code>​ 
 +<file config retour des commandes>​ 
 +bash((: Du texte >= 0 : erreur de syntaxe dans l'​expression (le symbole erroné est « texte >= 0 ») 
 +* (("Du texte" >= 0)) renvoie le code de retour 1 
 + 
 +bash: let: 424>Du texte : erreur de syntaxe dans l'​expression (le symbole erroné est « texte ») 
 +* let 424\>"​Du texte" renvoie le code de retour 1 
 + 
 +bash: ((: Du texte : erreur de syntaxe dans l'​expression (le symbole erroné est « texte ») 
 +* Avec n="Du texte" ; ((0<=n)) renvoie le code retour 1 
 + 
 +bash: let: Du texte : erreur de syntaxe dans l'​expression (le symbole erroné est « texte ») 
 +* Avec n="Du texte" ; let n==0 renvoie le code retour 1 
 +</​file>​ 
 + 
 +<​note>​ 
 +Remarquons que les commandes **let** et **<​nowiki>​((</​nowiki>​** renvoient le code de retour **1** quand elles sont en erreur. Ce n'est pas la norme pour une commande interne de bash. Le code de retour devrait être **2**. 
 +</​note>​ 
 + 
 +==== Exemple dans un script ==== 
 + 
 +Copions le code ci-dessous dans un fichier nommé mon_script. 
 + 
 +<code bash mon_script>
 #!/bin/bash #!/bin/bash
-var1=8 +a=8 ; b=2 
-var2=7 +if (( "$a" ​"$b" ​)) ; then 
-if test "$e" ​-gt "$f" ; then +  echo "$a < $b
-  echo " $var1 est plus grand que $var2 +else 
-fi +  echo "$a n'est pas inférieur à $b"
-echo " " +
-if test 8 -gt 7 ; then  +
-  echo " $var1 est plus grand que $var2 "+
 fi fi
 </​code>​ </​code>​
-retour de ./​mon-script :  
-<​code>​ 
- : ligne 18 : test:  : nombre entier attendu comme expression 
-  
- 8 est plus grand que 7 
-</​code>​ 
-</​note>​ 
-=====Conclusion sur les opérateurs lexicographiques et les opérateurs de comparaison numérique===== 
-====Yep, plus de confusions ! ==== 
-<​note>​ 
-**Nous avons vu :**\\  
  
-**1) qu'il y a deux mécanismes pour effectuer des tests, la paire de crochets et la commande test;​**\\ ​+Et exécutons le.
  
-**2) qu'à chaque mécanisme sa syntaxe :**\\  +<​code ​user
-<​code>​ +bash mon_script 
-test expression ​         ou bien     [ expression ]+echo $?
  
-$ test -f /​etc/​gaga ​                 $ [ -f /etc/gaga ] +rm -v mon_script
-$ echo $?                            $ echo $? +
-1                                    1 +
-$                                    $+
 </​code>​ </​code>​
 +<file config retour de la commande>​
 +8 n'est pas inférieur à 2
 +0
 +'​mon_script'​ supprimé
 +</​file>​
  
-(Si le fichier /etc/gaga existait**le code de retour** ​serait 0. **Voir la commande exit et son utilisation dans les scripts.**)\\ +__Remarque :__ L’exécution du script renverra toujours **0** (true)car le code de retour ​renvoyé est celui de la dernière commande exécutée, qui est **echo**.\\  
-  +(voir [[doc:programmation:shells:​script-bash-etat-de-sorie-et-les-tests#​utiliser-la-commande-exit|utilisation ​de la commande ​exit]]).
-**3) qu'il était possible de faire des tests sur [[atelier:chantier:la-page-man-bash-ii-les-operateurs-lexicographiques#​caracteres-de-comparaison-sur-les-chaines-de-caracteres|les chaînes ​de caractères]] (avec commande ​test ou les crochets) ; sur [[atelier:​chantier:​la-page-man-bash-ii-les-operateurs-lexicographiques#​tests-sur-les-fichiers|les fichiers]] (avec commande test ou les crochets).**\\ +
  
-**4) que, pour des comparaisons sur [[atelier:​chantier:​page-man-bash-iii-les-operateurs-de-comparaison-numerique#​operateurs-de-comparaison-numerique|les nombres]] on utilise :**\\  +==== Exemple dans une fonction ===
-  - soit **les doubles PARENTHÈSES** avec les opérateurs booléens : == ; !; > ; >; < ; <=.  +
-  - soit **les CROCHETS (ou la commande)** avec les opérateurs : -eq ; -ne ; -gt ; -ge ; -lt ; -le.\\ ​+
  
-**5qu'on utilise exclusivement les options -eq ; -ne ; -gt ; -ge ; -lt ; -le sur les nombres mais pas sur les chaînes de caractères** ;\\ +Nous créons ici une fonction (test_si_négatifqui teste si une expression numérique ou arithmétique est négative.
  
-**6) qu'on ne confondra pas avec les précédentes,​ les options qu'​on ​utilise ​exclusivement pour tester les fichiers : -e  ; -d  ; -f ; -L ; -r ; -w ; -x ; $fichier1 -nt $fichier2 ; $fichier1 -ot $fichier2 ​**+__Rappel :__ La commande ​**return** est identique à la commande **exit** (**return** s'​utilise ​dans une fonction, ​**exit** dans un script).
  
-</note>+<code user> 
 +test_si_négatif() { 
 + # Test_si_négatif <​expression>​ 
 + # Retourne le code de retour 0 si <​experssion>​ est négative 
 + # Retourne le code de retour 1 si <​experssion>​ est positive 
 + # Retourne le code de reour 2 si la fonction est mal utilisée 
 + local rc=2 # Initialise le paramètre rc avec la valeur 2 
 + if (( $# == 0 )) # Test si le nombre d'​argument est 0 
 + then #​ Si oui, 
 + echo "​Argument manquant"​ >&​2 #​ Retourne un message sur le canal d'​erreur 
 + elif (( $# > 1 )) # Si non, test si le nombre d'​argument est > à 1 
 + then #​ Si oui 
 + echo "Trop d'​arguments"​ >&​2 #​ Retourne un message sur le canal d'​erreur. 
 + elif (($1 >= 0)) # Si non, test si l'​argument est positif ou égale à 0 
 + then #​ Si oui, 
 + rc=1 #​ Affecte 1 au paramètre rc 
 + elif (($1 < 0)) # Si non, test si l'​argument est négatif 
 + then #​ Si oui, 
 + rc=0 #​ Affecte 0 au paramètre rc 
 + fi  
 + return $rc # Affecte $rc au code retour 
 +
 + 
 +test_si_négatif ;​ echo -e $?\\n 
 +test_si_négatif 42 ; echo $? 
 +test_si_négatif -42 ; echo $? 
 +test_si_négatif 42-84 ; echo $? 
 + 
 +unset test_si_négatif 
 +</code> 
 + 
 +Le troisième usage de notre fonction montre que la commande **<​nowiki>​((</​nowiki>​** évalue une expression arithmétique avant de la tester. 
 + 
 +<file config retour des commandes>​ 
 +Argument manquant 
 +
 + 
 +
 +
 +
 +</file>
  
-:-D 
  
 =====Pour aller plus loin : les opérateurs logiques.===== =====Pour aller plus loin : les opérateurs logiques.=====
-Ils s'​utilisent avec les tests.\\+=== Ils s'​utilisent avec les tests. ​===
 ^ Opérateur ^ Signification ^ ^ Opérateur ^ Signification ^
 |!         | Négation ​     | |!         | Négation ​     |
-|-a         | ET            | +|-a         | et            | 
-|-o         | OU            |+|-o         | ou            |
  
-Et dans un ordre précis :\\+=== Et dans un ordre précis : ===
   - ! (négation)   - ! (négation)
-  - -a (ET+  - -a (et
-  - -o (OU)+  - -o (ou)
  
 <note important>​ <note important>​
-**Il doit toujours y avoir un espace autour des opérateurs !, -a et -o.**\\ +  ​* Il doit toujours y avoir un espace autour des opérateurs: ''​!''​''​-a'',​ ''​-o''​. 
 +  
 +  ​Ne pas confondre ''​-a''​ (opérateur logique) avec un __opérateur de test__ sur les fichiers.
  
-**Ne pas confondre -(opérateur logique) pour un opérateur de test sur les fichiers.**\\ +  ​* Ne pas confondre ​''​-o'' ​(opérateur logique) ​avec ''​-ot''​ (test pour savoir si un fichier1 est plus ancien qu'un fichier2.
  
-**Ne pas confondre -o (opérateur logique) avec -ot (test pour savoir si un fichier1 ​est plus ancien qu'un fichier2.**\\ +  ​Il est possible de modifier la priorité d'exécution des opérateurs en utilisant des parenthèses. 
 + 
 +  ​Les parenthèses doivent être protégées par des anti-slash afin de ne pas être interprétées par le shell comme étant un regroupement de commandes: ​\\''​\(...\)''​
  
-**Il est possible de modifier la priorité d'​exécution des opérateurs en utilisant des paranthèses.**\\ ​ 
-\(........\)\\ ​ 
-Les parenthèses doivent être protégées par des anti-slash afin de ne pas être interprétées par le shell comme étant un regroupement de commandes. ​ 
 </​note>​ </​note>​
-  * syntaxe ​+ 
-Le fichier "​toto"​ n'est pas un répertoire : +=== Exemples ​=== 
-<​code>​+  ​* ​Le fichier "​toto"​ n'est pas un répertoire : 
 +<​code ​user>
 [ ! -d /etc/group ] [ ! -d /etc/group ]
- echo $? 
-0 
 </​code>​ </​code>​
 +<code user>
 +echo $?
 +</​code>​
 +<file config retour de la commande>​
 + 0
 +</​file>​
 +>Il est vrai (retour 0) que ce "​n'​est pas" ;-)
  
-Le fichier mon-script existe et est exécutable : +  * Le fichier mon-script existe et est exécutable : 
-<​code>​+<​code ​user>
 [ -f mon-script -a -x mon-script ] [ -f mon-script -a -x mon-script ]
 +</​code>​
 +<code user>
 echo $? echo $?
-0 
 </​code>​ </​code>​
 +<file config retour de la commande>​
 + 0
 +</​file>​
 +=====Tuto précédent=====
  
-===Tuto précédent=== +[[doc:programmation:​shells:​la-page-man-bash-ii-les-operateurs-lexicographiques|Bash : les opérateurs lexicographiques]]
- +
-[[atelier:chantier:​la-page-man-bash-ii-les-operateurs-lexicographiques|Bash : les opérateurs lexicographiques]]+
  
-===La suite c'est ici : ===+=====La suite c'est ici : =====
  
-[[atelier:chantier:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques|Bash : les symboles dans les calculs]]+[[doc:programmation:​shells:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques|Bash : les symboles dans les calculs]]
doc/programmation/shells/page-man-bash-iii-les-operateurs-de-comparaison-numerique.txt · Dernière modification: 30/09/2023 23:06 (modification externe)

Pied de page des forums

Propulsé par FluxBB