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
doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique [15/02/2023 21:52]
ubub [Comparaison numérique avec ((]
doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique [30/09/2023 23:06] (Version actuelle)
Ligne 1: Ligne 1:
 ======Bash : les opérateurs de comparaison numérique====== ======Bash : les opérateurs de comparaison numérique======
  
-  * 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 par les caractère. 
-  * Niveau requis : {{tag>​débutant ​avisé}} +  * Niveau requis : {{tag>​débutant}} 
-  * Commentaires : FIXME +  * Commentaires : Bash, ligne de commande et scripts ​
   * 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 : +  * Suivi :  ​{{tag>​à-tester}}
     * Création par [[user>​Hypathie]] le 08/04/2014     * Création par [[user>​Hypathie]] le 08/04/2014
     * Testé par [[user>​Hypathie]] en Avril 2014     * Testé par [[user>​Hypathie]] en Avril 2014
 +    * Modifié par [[user>​agp91]] le 21/02/2022
   * 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 !))   * 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 !))
  
 **Nota :** Contributeurs,​ les FIXME sont là pour vous aider, supprimez-les une fois le problème corrigé ou le champ rempli ! **Nota :** Contributeurs,​ les FIXME sont là pour vous aider, supprimez-les une fois le problème corrigé ou le champ rempli !
- 
  
   * [[doc:​programmation:​shells:​bash-les-differents-caracteres-speciaux|Vision d'​ensemble]]   * [[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-les-caracteres-speciaux|Détail et caractères]]
-  * [[doc:​programmation:​shells:​la-page-man-bash-ii-les-operateurs-lexicographiques|Les opérateurs ​lexicographiques]] +  ​* [[atelier:​chantier:​bash:​les-operateurs-sur-parametres|Les opérateurs de test sur paramètres]] 
-  * ;-) +  ​* [[doc:​programmation:​shells:​la-page-man-bash-ii-les-operateurs-lexicographiques|Les opérateurs ​de test sur chaînes]] 
-  * [[doc:​programmation:​shells:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques|Les symboles dans les calculs]] +  ​* [[atelier:​chantier:​bash:​les-operateurs-de-test-sur-fichiers|Les opérateurs de test sur fichiers]] 
-  * [[doc:​programmation:​shells:​page-man-bash-v-les-tableaux|Les tableaux]]+  * **Les opérateurs de comparaison numérique** ;-) 
 +  * [[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|Bash : les tableaux]] ​
   * [[doc:​programmation:​shells:​man-bash-vi-les-caracteres-de-transformation-de-parametres|Les caractères de transformation de parametres]]   * [[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]]   * [[doc:​programmation:​shells:​bash-vii-globs-etendus-regex|Bash : Variables, globs étendus, ERb, ERe]]
- 
 ===== Introduction ===== ===== Introduction =====
  
-En interne, bash dispose de plusieurs commandes pour réaliser des comparaisons numériques:​ +<note> 
-  *La commande composée **<nowiki>((</​nowiki>​** et la commande ​**let**. +Dans la page du manuel de bash, **les opérateurs des commandes ​de test** sont nommés __**primitives**__
-  *Les commandes **[** et **test**. +</note>
-  *Et la commande composée **<​nowiki>​[[</nowiki>**.+
  
-Les commandes **[** et **test** sont disponibles dans leurs versions externe : **/​usr/​bin/​[** et **/​usr/​bin/​test**.+Bash dispose de plusieurs ​commandes ​pour **réaliser des comparaisons numérique**.
  
-__Rappels :__ +  ​Les commandes ​de test : 
-  ​Une commande ​de test renvoie le code de retour true (0) lorsque le test réussi et false (1) lorsqu'​il échoue.  +    * Les commandes ​internes ​**[** et **test**. 
-  * Le code retour d'une commande est mémorisé dans le paramètre spécial **$?**. +    Et la commande ​composée ​**<​nowiki>​[[</​nowiki>​**. 
-  * L'​opérateur **<​nowiki>&&</​nowiki>​** exécute la commande suivante, si la commande précédente à renvoyée le code retour true (égale à 0). +  Les commandes ​d'évaluation numériques ​
-  * L'​opérateur **<​nowiki>​||</​nowiki>​** exécute la commande suivante, si la commande précédente à renvoyée le code retour false (différent de 0). +    * La commande ​composée ​**<​nowiki>​((</​nowiki>​** et la commande ​interne ​**let**.
- +
- +
-===== Comparaison numérique avec (( ===== +
- +
-Syntaxe ​+
-<​code>​ +
-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. +
-Avec la commande ​**let**, les opérateurs commençant par **<** ou **>** doivent être protégés (voir plus bas : Mauvais usages). +
-</​code>​ +
- +
-__Remarque :__ Les commandes **let** et **<​nowiki>​((</​nowiki>​** sont pratiquement équivalentes (voir les différences plus bas Mauvais usages)+
- +
-|  Opérateurs de comparaison numérique de la commande <​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 | +
- +
-==== Exemples dans le terminal ==== +
- +
-<code user> +
-(( 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>​ +
-<file config retour des commandes>​ +
-+
-+
-</​file>​ +
- +
-<code user> +
-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>​ +
-<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> +
-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>​ +
-<file config retour des commandes>​ +
-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, son développement renverra **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>​ +
-<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>​ +
- +
-Avec la commande **<​nowiki>​((</​nowiki>​**, les espaces ne sont pas obligatoires+
-<code user> +
-n1=4242 +
-n2=2424 +
-if ((n1>​n2)) +
-then +
- echo "$n1 est supérieur à $n2" +
-else +
- echo "$n1 est inférieur à $n2" +
-fi +
- +
-unset n1 n2 +
-</​code>​ +
-<file config retour de la commande>​ +
-4242 est supérieur à 2424 +
-</​file>​ +
- +
-==== Mauvais usages ==== +
- +
-La commande ​**let** ne supporte pas les espaces entre les opérandes et l'​opérateur. +
- +
-<code user> +
-let -42 \< 0 ; echo $? +
-let 0 == 0 ; echo $? +
-</​code>​ +
-<file config retour des commandes+
-bash: let: < : erreur de syntaxe : opérande attendu (le symbole erroné est « <​ ») +
-+
-bash: let: == : erreur de syntaxe : opérande attendu (le symbole erroné est « == ») +
-+
-</​file>​ +
- +
-Avec la commande **let**, 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>​ +
-(( == 0)) ; echo $? +
-let 0>= ; echo $? +
-echo ===== +
-(( 42 < ""​)) ;​ echo $? +
-let ""​!=24 ;​ echo $? +
-</​code>​ +
-<file config retour des commandes>​ +
-bash: ((: == 0 : erreur de syntaxe : opérande attendu (le symbole erroné est « == 0 ») +
-+
-bash: let: une expression est attendue +
-+
-===== +
-bash: ((: 42 <  : erreur de syntaxe : opérande attendu (le symbole erroné est « <  ») +
-+
-bash: let: !=24 : erreur de syntaxe : opérande attendu (le symbole erroné est « !=24 ») +
-+
-</​file>​ +
- +
-Les opérandes ne peuvent être des chaînes de caractères contenant des espaces. +
- +
-__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>​ +
-echo ===== +
-(("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 +
-echo ===== +
-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 $?" +
-</​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>​ <​note>​
-Remarquons que les commandes ​**let** et **<​nowiki>​((</​nowiki>​** ​renvoient le code de retour ​**1** quand elles sont en erreurCe n'est pas la norme pour une commande interne ​de bash. Le code de retour devrait être **2**.+  * 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>​ </​note>​
  
-==== Exemple dans un script ====+<​note>​ 
 +__Rappels :__
  
-Copions ​le code ci-dessous ​dans un fichier nommé mon_script.+  *  Une commande de test renvoie ​le code de retour **0** (considéré comme vrai) lorsque le test réussi et **1** (considéré comme faux) lorsqu'​il échoue. 
 +  *  Le code retour d'une commande est mémorisé ​dans le paramètre spécial **$?**. 
 +  *  L'​opérateur de contrôle **&&​** exécute la commande suivante, si la commande précédente a renvoyé ​un code de retour égal à **0**. 
 +  *  L'​opérateur de contrôle **||** exécute la commande suivante, si la commande précédente a renvoyé un code de retour supérieur à **0**. 
 +</​note>​
  
-<code bash mon_script>​ +===== Comparaison numérique avec [ et [[ =====
-#​!/​bin/​bash +
-a=8 ; b=+
-if (( "​$a"​ < "​$b"​ )) ; then +
-  echo "$a < $b" +
-else +
-  echo "$a n'est pas inférieur à $b" +
-fi +
-</​code>​+
  
-Et exécutons le.+Les commandes de test dispose de 6 primitives binaires pour effectuer des comparaisons numériques.
  
-<code user> +==== Syntaxe ====
-bash mon_script +
-echo $?+
  
-rm -v mon_script +  ​* **test expr1 OP expr2** 
-</​code>​ +  ​* **[ expr1 OP expr2 ]** 
-<file config retour de la commande>​ +  ​* **<​nowiki>​[[</​nowiki> ​expr1 OP <​nowiki>​expr2</​nowiki> ​]]**
-8 n'est pas inférieur à 2 +
-+
-'​mon_script'​ supprimé +
-</​file>​ +
- +
-__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]]). +
- +
-==== Exemple dans une fonction === +
- +
-Nous créons ici une fonction (test_si_négatif) qui teste si une expression numérique ou arithmétique est négative. +
- +
-__Rappel :__ La commande ​**return** est identique à la commande **exit** (**return** s'​utilise dans une fonction, **exit** dans un script). +
- +
-<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>​ +
-===== Comparaison numérique avec [ et [[ ===== +
-La comparaison numérique peut aussi se réaliser avec les commandes **[** (ou **test**) et **<​nowiki>​[[</​nowiki>​**+
- +
-Syntaxe : +
-<​code>​ +
-test expr1 OP expr2 +
-[ expr1 OP expr2 ] +
-[[ expr1 OP expr2 ]] +
-   +
-expr1 et expr2 sont sujets au développement des paramètres. +
-Avec la commande [[, expr1 et expr2 sont sujets à l’évaluation arithmétique. La commande [ (ou test), ne le permet pas. +
-Avec OP, l'un des opérateurs du tableau suivant. +
-</​code>​+
  
-__Rappel ​:__ Les commandes **[** et **test** ​sont équivalentes.+  * 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.
  
-|  ​Opérateurs ​de comparaison ​des commandes [ et <​nowiki>​[[</​nowiki> ​ || +|  ​Liste des primitives ​de comparaison ​numérique ​ || 
-^Opérateurs ​   ​Significations ​        ^+^Primitives Retours ^
 |''​-eq ''​ | est égal à | |''​-eq ''​ | est égal à |
 |''​-ne ''​ | n'est pas égal à | |''​-ne ''​ | n'est pas égal à |
Ligne 371: Ligne 78:
 |''​-le ''​ |est plus petit ou égal à | |''​-le ''​ |est plus petit ou égal à |
  
-==== Exemples ​dans le terminal ​====+==== Exemples ====
  
 <code user> <code user>
 [ 25 -eq 20 ] # Teste si 25 est égale à 20 [ 25 -eq 20 ] # Teste si 25 est égale à 20
 echo $? echo $?
 +</​code><​code>​
 +
 </​code>​ </​code>​
-<file config retour de la commande>​ 
- 
-</​file>​ 
  
 <code user> <code user>
Ligne 389: Ligne 95:
  
 unset var1 var2 unset var1 var2
-</​code>​ +</​code><​code>
-<file config retour de la commande>+
 17 est-il plus grand que 18 : 1 17 est-il plus grand que 18 : 1
 17 est-il plus petit que 18 : 0 17 est-il plus petit que 18 : 0
 17 est-il différent de 18 : 0 17 est-il différent de 18 : 0
 +</​code>​
 +
 +Copions le code ci-dessous dans le fichier **mon_script**.\\ ​
 +Puis exécutons le avant de le supprimer.
 +
 +<code bash mon_script>​
 +#!/bin/bash
 +a=2 ; b=1
 +if [ "​$a"​ -gt "​$b"​ ] ; then
 + echo "$a est plus grand que $b"
 +fi
 +
 +if test 100 -gt 99
 +then
 + echo "​vrai" ​  #​réponse : vrai
 +else
 + echo "​faux"​
 +fi    ​
 +</​code><​code user>
 +bash mon_script
 +
 +rm -f mon_script
 +</​code><​file>​
 +2 est plus grand que 1
 +vrai
 +'​mon_script'​ supprimé
 </​file>​ </​file>​
  
-==== Particularités de la commande [[ ====+==== Particularités de la commande ​<​nowiki>​[[</​nowiki> ​====
  
 Seule la commande **<​nowiki>​[[</​nowiki>​** permet de tester une expression arithmétique. Seule la commande **<​nowiki>​[[</​nowiki>​** permet de tester une expression arithmétique.
Ligne 406: Ligne 137:
  
 [[ 84-42 -eq 42 ]] ; echo $? [[ 84-42 -eq 42 ]] ; echo $?
-</​code>​ +</​code><​code>
-<file config retour des commandes>+
 bash: test: 21+21 : nombre entier attendu comme expression bash: test: 21+21 : nombre entier attendu comme expression
 2 2
Ligne 415: Ligne 145:
  
 0 0
-</file+</code
- +<​note>​ 
-__Rappel :__ Lorsque le code de retour d'une commande interne ​renvoie ​**2**, cela signifie un mauvais usage de cette commande.+Lorsqu'une commande interne **le code de retour renvoie ​2**, cela signifie un mauvais usage de cette commande. 
 +</​note>​
  
 Elle est aussi la seule à accepter les chaînes vides qui sont alors évaluées à **0**. Elle est aussi la seule à accepter les chaînes vides qui sont alors évaluées à **0**.
Ligne 425: Ligne 156:
 [[ ""​ -ne 0 ]] ; echo $? [[ ""​ -ne 0 ]] ; echo $?
 [[ ""​ -eq ""​ ]] ; echo $? [[ ""​ -eq ""​ ]] ; echo $?
-</​code>​ +</​code><​code>
-<file config retour des commande>+
 0 0
 1 1
 0 0
-</file>+</code>
  
 Idem pour les chaînes de caractères sans espace (mots). Un mot est substitué par **0**. Idem pour les chaînes de caractères sans espace (mots). Un mot est substitué par **0**.
Ligne 438: Ligne 168:
 [[ 0 -ne mot ]] ; echo $? [[ 0 -ne mot ]] ; echo $?
 [[ mot1 -eq mot2 ]] ; echo $? [[ mot1 -eq mot2 ]] ; echo $?
-</​code>​ +</​code><​code>
-<file config retour des commandes>+
 0 0
 1 1
 0 0
 +</​code>​
 +
 +<note important>​
 +Attention :
 +<code bash mon_script>​
 +#!/bin/bash
 +var1=8
 +var2=7
 +if test "​$e"​ -gt "​$f"​ ; then
 +  echo " $var1 est plus grand que $var2 "
 +fi
 +printf \\n
 +test 8 -gt 7 && echo "$var1 est plus grand que $var2"
 +</​code>​
 +
 +<code user>
 +bash mon_script
 +
 +rm -v mon_script
 +</​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>​ </​file>​
 +</​note>​
  
 ==== Mauvais usages ==== ==== Mauvais usages ====
  
-Le caractère **$** est obligatoire pour développer les arguments. Sans, ils sont interprétés comme des mots.+Le caractère **$** est obligatoire pour développer les paramètres. Sans, ils sont interprétés comme des mots.
  
 Avec la commande **[** (ou **test**), les chaînes vides ou les mots sont à proscrire. Avec la commande **[** (ou **test**), les chaînes vides ou les mots sont à proscrire.
Ligne 457: Ligne 212:
 test ""​ -gt 42 ; echo $? test ""​ -gt 42 ; echo $?
 [ ""​ -ge 42 ] ; echo $? [ ""​ -ge 42 ] ; echo $?
-</​code>​ +</​code><​code>
-<file config retour des commande>+
 bash: test:  : nombre entier attendu comme expression bash: test:  : nombre entier attendu comme expression
 2 2
Ligne 468: Ligne 222:
 bash: [:  : nombre entier attendu comme expression bash: [:  : nombre entier attendu comme expression
 2 2
-</file>+</code>
  
 <code user> <code user>
Ligne 476: Ligne 230:
 [ "​mot"​ -ge 0 ] ; echo $? [ "​mot"​ -ge 0 ] ; echo $?
 echo $? echo $?
-</​code>​ +</​code><​code>
-<file config retour des commandes>+
 bash: test: mot : nombre entier attendu comme expression bash: test: mot : nombre entier attendu comme expression
 2 2
Ligne 486: Ligne 239:
 bash: [: mot : nombre entier attendu comme expression bash: [: mot : nombre entier attendu comme expression
 2 2
-</file>+</code>
  
 Avec **[** (ou **test**) et **<​nowiki>​[[</​nowiki>​**,​ les opérandes ne peuvent être des chaînes de caractères qui comportent des espaces. Avec **[** (ou **test**) et **<​nowiki>​[[</​nowiki>​**,​ les opérandes ne peuvent être des chaînes de caractères qui comportent des espaces.
Ligne 494: Ligne 247:
 [ 0 -ge "Du texte" ] ; echo $? [ 0 -ge "Du texte" ] ; echo $?
 [[ "Du texte" -ge 0 ]] ; echo $? [[ "Du texte" -ge 0 ]] ; echo $?
-</​code>​ +</​code><​code>
-<file config retour des commandes>+
 bash: test: Du texte : nombre entier attendu comme expression bash: test: Du texte : nombre entier attendu comme expression
 2 2
 bash: [: Du texte : nombre entier attendu comme expression bash: [: Du texte : nombre entier attendu comme expression
 2 2
-bash: [[: Du texte : erreur de syntaxe dans l'​expression (le symbole erroné est « texte »)+bash: [[: Du texte : erreur de syntaxe dans l'​expression (le symbole erroné est « texte »)
 1 1
-</file>+</code> 
 <note > <note >
-Il est remarquable que le test ''<​nowiki>​[[ "Du texte" -ge 0 ]]</​nowiki>'',​ ne renvoie pas le code de retour ​**2**.\\ ​+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>''​. Pourtant il s'agit bien d'un mauvais usage de la commande ''<​nowiki>​[[</​nowiki>''​.
 </​note>​ </​note>​
Ligne 520: Ligne 273:
 [[ -le 42 ]] [[ -le 42 ]]
 echo $? echo $?
-</​code>​ +</​code><​code>
-<file config retour des commandes>+
 bash: test: 42 : opérateur unaire attendu bash: test: 42 : opérateur unaire attendu
 2 2
Ligne 537: Ligne 289:
 bash: erreur de syntaxe près de « 42 » bash: erreur de syntaxe près de « 42 »
 2 2
-</​file>​ 
- 
-Ainsi que les espaces. 
- 
-<code user> 
-[24 -ne 24 ] ; echo $? 
-[[24 -le 24 ]] 
-echo $? 
-echo ==== 
-[ 24 -ne 24] ; echo $? 
-[[ 24 -le 24]] 
-echo $? 
-echo ==== 
-test 42-gt 0 ; echo $? 
-[ 42 -eq0 ] ; echo $? 
-[[ 42 -ne0 ]] 
-echo $? 
 </​code>​ </​code>​
-<file config retour des commandes>​ 
-bash: [24 : commande introuvable 
-127 
-bash: [[24 : commande introuvable 
-127 
-==== 
-bash: [: « ] » manquant 
-2 
-bash: erreur de syntaxe dans une expression conditionnelle 
-bash: erreur de syntaxe près de « echo » 
-==== 
-bash: test: 42-gt : opérateur unaire attendu 
-2 
-bash: [: 42 : opérateur unaire attendu 
-2 
-bash: opérateur binaire conditionnel attendu 
-bash: erreur de syntaxe près de « -ne0 » 
-2 
-</​file>​ 
- 
-__Rappel :__ Le code retour 127, signifie que la commande n'a pas été trouvée. 
  
 +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\\ ​ 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\\ ​
 Puisque la chaîne est non vide, le test n'​échoue pas. Puisque la chaîne est non vide, le test n'​échoue pas.
 +
 <code user> <code user>
 test 420-ne420 ; echo $? test 420-ne420 ; echo $?
 [ 420-gt42 ] ; echo $? [ 420-gt42 ] ; echo $?
 [[ 42-lt420 ]] ; echo $? [[ 42-lt420 ]] ; echo $?
-</​code>​ +</​code><​code>
-<file config retour des commandes>+
 0 0
 0 0
 0 0
-</file>+</code>
  
 Ne pas utiliser les opérateurs **<** et **>** avec **[** (ou **test**) et **<​nowiki>​[[</​nowiki>​** pour réaliser des comparaisons numériques.\\ ​ 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.\\ ​ 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 ​lexicographiques]]).+(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]]). __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]]).
Ligne 608: Ligne 323:
 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. 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.
  
-==== Exemples dans un script ​====+===== Comparaison numérique avec (( =====
  
-Copions le code ci-dessous dans le fichier mon_script.+La commandes d'​évaluation numérique **<​nowiki>​((</​nowiki>​** (commande composée) et la commande **let** (commande interne), permettent de réaliser des comparaisons numériques.\\  
 +Elles disposent de 6 opérateurs de comparaison.
  
-<code bash mon_script>​ +==== Syntaxe ====
-#​!/​bin/​bash +
-a=2 ; b=+
-if [ "​$a"​ -gt "​$b"​ ] ; then +
- echo "$a est plus grand que $b" +
-fi+
  
-if test 100 -gt 99 +  * **let expr1<​OP>​expr2** 
-then +  * **let "expr1 <OP> expr2"** 
- echo "vrai" ​  #réponse : vrai +  * **<​nowiki>​((</​nowiki>​ <​expr1>​ <OP> <​expr2>​ <​nowiki>​))</​nowiki>​** 
-else + 
- echo "​faux"​ +  * Avec : 
-fi     +    * **Expr1** et **expr2** sont sujets au développement des paramètres et à l’évaluation arithmétique. 
-</code>+    * **<​OP>​** l'un des opérateurs donnés dans le tableau suivant. 
 + 
 +|  Opérateurs de comparaison numérique des commandes let et <​nowiki>​((</nowiki || 
 +^ Opérateurs ^ Retours ^ 
 +| ''​ == ''​ | Vrai si égale | 
 +| ''​ != ''​ | Vrai si différent | 
 +| ''​ > ''​ | Vrai si plus grand que | 
 +| '' ​ >= ''​ | Vrai si plus grand ou égal que | 
 +| ''​ < ''​ | Vrai si plus petit que | 
 +| ''<​nowiki><​=</​nowiki>​ ''​ | Vrai plus petit ou égal que | 
 + 
 +<​note>​ 
 +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]].) 
 +</​note>​ 
 + 
 +==== Exemples ====
  
 <code user> <code user>
-bash mon_script+(( 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><​file>​ 
 +
 +
 +</​file>​
  
-rm -f mon_script +<code user> 
-</​code>​ +nombre1=12 
-<​file ​config retour de la commande+nombre2=13 
-2 est plus grand que +(( $nombre1 > $nombre2 )) # Est-ce-que nombre1 (12) est strictement supérieur au nombre2 (13). 
-vrai +echo $? # Affiche le code de retour. 
-'​mon_script'​ supprimé+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><​file>​ 
 +
 +0
 </​file>​ </​file>​
  
-<note important+Les paramètres peuvent être transmis sans **$** (Sauf les paramètres positionnels et les paramètres spéciaux). 
-Attention :+ 
 +<code user
 +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><​file>​ 
 +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><​file>​ 
 +(("​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> 
 +n= 
 +((n==0)) ; echo $? 
 +let 'n != 0' ; echo $? 
 + 
 +unset n 
 +</​code><​file>​ 
 +
 +
 +</​file>​ 
 +Avec la commande **<​nowiki>​((</​nowiki>​**,​ les espaces ne sont pas obligatoires. 
 +<code user> 
 +n1=4242 
 +n2=2424 
 +if ((n1>​n2)) 
 +then 
 + echo "$n1 est supérieur à $n2" 
 +else 
 + echo "$n1 est inférieur à $n2" 
 +fi 
 + 
 +unset n1 n2 
 +</​code><​file>​ 
 +4242 est supérieur à 2424 
 +</​file>​ 
 + 
 +Copions le code ci-dessous dans un fichier nommé **mon_script**.\\  
 +Puis exécutons avant de le supprimer. 
 <code bash 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 
 +  echo "$a n'est pas inférieur à $b"
 fi fi
-printf \\n +</​code><​code user>
-test 8 -gt 7 && echo "$var1 est plus grand que $var2"​ +
-</​code>​ +
- +
-<code user>+
 bash mon_script bash mon_script
 +echo $?
  
 rm -v mon_script rm -v mon_script
-</​code>​ +</​code><​file>​ 
-<​file ​config retour de la commande> +n'est pas inférieur à 2 
-mon_script: ligne 4 : test:  : nombre entier attendu comme expression +0
- +
-8 est plus grand que 7 +
 '​mon_script'​ supprimé '​mon_script'​ supprimé
 </​file>​ </​file>​
-</​note>​ + 
-=====Conclusion sur les opérateurs lexicographiques ​et les opérateurs ​de comparaison numérique===== +L’exécution du script renverra toujours **0** (vrai), car le code de retour renvoyé est celui de la dernière commande exécutée, qui est **echo**.\\  
-====Yepplus de confusions ! ====+(voir : [[doc:​programmation:​shells:​script-bash-etat-de-sorie-et-les-tests#​utiliser-la-commande-exit|Utilisation ​de la commande exit]]). 
 + 
 +Maintenantnous allons créer une fonction (**test_si_négatif**) qui teste si une expression numérique ou arithmétique est négative. 
 <​note>​ <​note>​
-Nous avons vu :\\ +La commande **return** est identique à la commande **exit** (**return** s'​utilise dans une fonction, **exit** dans un script). 
 +</​note>​
  
-  * qu'il y a deux mécanismes pour effectuer des tests, la paire de crochets et la commande ​test+<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 
 +}
  
-  * qu'à chaque mécanisme sa syntaxe :  +test_si_négatif ;​ echo -e $?\\n 
-<​code>​ +test_si_négatif 42 ; echo $
-test -f /etc/gaga +test_si_négatif ​-42 ; echo $? 
-</​code>​+test_si_négatif 42-84 ; echo $?
  
-Ou +unset test_si_négatif 
 +</​code><​code>​ 
 +Argument manquant 
 +2
  
-<​code>​ +1 
-$ [ -f /etc/gaga ]+
 +0
 </​code>​ </​code>​
-(Si le fichier /etc/gaga existait, //le code de retour// serait 0.\\ Voir la commande exit et son utilisation dans les scripts.) 
  
-  * qu'il était possible ​de faire des tests avec commande test ou les crochets sur [[doc:​programmation:​shells:​la-page-man-bash-ii-les-operateurs-lexicographiques#​caracteres-de-comparaison-sur-les-chaines-de-caracteres|les chaînes ​de caractères]] ; et [[doc:​programmation:​shells:​la-page-man-bash-ii-les-operateurs-lexicographiques#​tests-sur-les-fichiers|les fichiers]]+Le 4eme usage de notre fonction montre que la commande **<​nowiki>​((</​nowiki>​** évalue une expression arithmétique avant de la tester.
  
-  ​quepour des comparaisons sur [[doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique|les nombres]] on utilise ​+==== Mauvais usages ==== 
-soit les doubles parenthèses avec les opérateurs ​booléens :+ 
 +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><​file>​ 
 +bashleterreur de syntaxe : opérande attendu (le symbole erroné est « <​ ») 
 +
 +bash: let: == : erreur de syntaxe : opérande attendu (le symbole erroné est « == ») 
 +
 +</​file>​ 
 + 
 + 
 +Avec la commande **let**, si l'​expression à évaluer est protégé par des guillemets simples,\\  
 +Les paramètres sont développés uniquement s'ils ne disposent pas du caractère **$**.\\  
 +S'il est fourni, une erreur est renvoyée. 
 + 
 +<code user> 
 +n=42 
 +let '​n==42'​ ;​ echo $? 
 +let '$n > 42' ; echo $? 
 +</​code><​file>​ 
 +
 +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 : 
 + 
 +<​note>​ 
 +La commande **printf "​\n"​**,​ renvoie un saut de ligne.\\  
 +La commande **echo ​-n**, n'​ajoute pas de saut ligne à la fin de son retour. 
 +</​note>​ 
 + 
 +<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>​ 
 +bashlet: 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>​
- ==    ​!= ​  <​ > ​  >=   <+(( == 0)) ; echo $? 
-</​code>​ +let 0>= ; echo $? 
-soit les crochets ​(ou la commande ​"test"​) ​avec les opérateurs :  +echo ====
-<​code>​ +(( 42 < ""​)) ; echo $? 
--eq   ​-ne ​  ​-gt ​  ​-ge ​  ​-lt ​  -le+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>​
  
-  * qu'on utilise exclusivement les opérateurs ''​-eq''​ ; ''​-ne''​ ; ''​-gt''​ ; ''​-ge''​ ; ''​-lt''​ ; ''​-le''​ sur les nombres mais pas sur les chaînes de caractères ; 
  
-  * qu'​enfin il ne faut pas confondre pas avec les opérateurs précédents,​ les options qu'on utilise exclusivement pour tester les fichiers :''-e'' ​ ; ''​-d'';​ ''​-f''​ ; ''​-L''​ ; ''​-r''​ ; ''​-w''​ ; ''​-x''​ ; $fichier1 ''​-nt''​ $fichier2 ; $fichier1 ''​-ot''​ $fichier2+Les opérandes ​ne peuvent être des chaînes de caractères contenant des espaces. 
 +<​note>​ 
 +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**). 
 +</​note>​
  
-Plein d'exemples ​dans ce wiki en anglais ​[[http://wiki.bash-hackers.org/​commands/​classictest]]+<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>​ 
 +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 
 + 
 +bashlet424>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 erreurCe n'est pas la norme pour une commande interne de bash. Le code de retour devrait être **2**.
 </​note>​ </​note>​
  
-:-D 
  
 =====Pour aller plus loin : les opérateurs logiques.===== =====Pour aller plus loin : les opérateurs logiques.=====
Ligne 753: Ligne 704:
 =====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:bash:les-operateurs-de-test-sur-fichiers|Bash : Les opérateurs ​de test sur fichiers]]
  
 =====La suite c'est ici : ===== =====La suite c'est ici : =====
  
 [[doc:​programmation:​shells:​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.1676494374.txt.gz · Dernière modification: 15/02/2023 21:52 par ubub

Pied de page des forums

Propulsé par FluxBB