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 Les deux révisions suivantes
doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique [14/02/2023 12:01]
agp91 [Comparaison numérique avec ((]
doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique [14/02/2023 16:25]
agp91 [Comparaison numérique avec ((]
Ligne 35: Ligne 35:
 (( expr1 OP expr2 )) (( expr1 OP expr2 ))
  
-expr1 et expr2 sont sujets au développement des paramètres et au développement ​arithmétique.+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 OP l'un des opérateurs donnés dans le tableau suivant.
 </​code>​ </​code>​
Ligne 42: Ligne 42:
 |Opérateurs de comparaison numérique de la commande <​nowiki>​((</​nowiki>​ || |Opérateurs de comparaison numérique de la commande <​nowiki>​((</​nowiki>​ ||
 ^ Opérateurs ^ Description ^ ^ Opérateurs ^ Description ^
-| ''​ == ''​ | Comparaison d'un égalité ​             |+| ''​ == ''​ | Comparaison d'une égalité ​             |
 | ''​ != ''​ | Comparaison d'une différence ​         | | ''​ != ''​ | Comparaison d'une différence ​         |
 | ''​ > ''​ | Comparaison de plus grand que         | | ''​ > ''​ | Comparaison de plus grand que         |
Ligne 89: Ligne 89:
 </​file>​ </​file>​
  
-Le développement des opérandes doivent être des valeurs ​numérique.\\  +Le développement des opérandes doivent être des valeurs ​numériques.\\  
-Mais comme nous l'​avons vu au dessus, les paramètre n'ont pas besoin du meta caractère $ pour être développé.\\ ​+Mais comme nous l'​avons vu au dessus, les paramètre n'ont pas besoin du caractère $ pour être développé.\\ ​
 Un simple mot sera alors interprété comme un paramètre.\\ ​ Un simple mot sera alors interprété comme un paramètre.\\ ​
 Si ce paramètre n'​existe pas, son développent retournera 0. Si ce paramètre n'​existe pas, son développent retournera 0.
  
-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égé le caractère de protection (\\n). +__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).\\  
-<​code>​+Le développement des caractères protégés se réalisent entre guillemets doubles.\\  
 +Sans guillemets, il est nécessaire de protégé le caractère de protection (\\n). 
 + 
 +<​code ​user>
 echo ========== echo ==========
 (("Du texte" >= 0)) (("Du texte" >= 0))
Ligne 127: Ligne 130:
  
 ==== Exemple dans un script ==== ==== Exemple dans un script ====
 +
 +Copions le code ci-dessous dans un fichier nommé mon_script.
  
 <code bash mon_script>​ <code bash mon_script>​
Ligne 132: Ligne 137:
 a=8 ; b=2 a=8 ; b=2
 if (( "​$a"​ < "​$b"​ )) ; then if (( "​$a"​ < "​$b"​ )) ; then
-  echo " $a < $b "+  echo "$a < $b"
 else else
   echo "$a n'est pas inférieur à $b"   echo "$a n'est pas inférieur à $b"
 fi fi
 </​code>​ </​code>​
 +
 +Et exécutons le.
  
 <code user> <code user>
 bash mon_script bash mon_script
 echo $? echo $?
 +
 +rm -v mon_script
 </​code>​ </​code>​
 <file config retour de la commande>​ <file config retour de la commande>​
 8 n'est pas inférieur à 2 8 n'est pas inférieur à 2
 0 0
 +'​mon_script'​ supprimé
 </​file>​ </​file>​
  
-Remarque ​: L’exécution du script retournera 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]]).+__Remarque ​:__ L’exécution du script retournera 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]]).
  
-<note important>​ +==== Exemple dans une fonction ===
-Attention à la confusion avec les tests sur les chaînes de caractères ! +
-<code bash script>​ +
-#​!/​bin/​bash +
-a=23 +
-b=+
-if (( "​$a"​ < "​$b"​ )) ; then +
- echo "$a > $b" +
-else +
- echo "aïe : $a < $b ???"  +
-fi +
-echo " " +
-  +
-c="​23"​ +
-d="​24"​ +
-if test "​$c"​ > "​$d"​ ; then +
-  echo "​Attention ! incohérence "​$c"​ > "​$d"​ car avec test et crochets,  +
-        il s'agit de tests sur les chaînes de caractères."​ +
-fi +
-echo " " +
-  +
-e="​26"​ +
-f="​25"​ +
-if [ "​$e"​ > "​$f"​ ] ; then  +
-  echo "De même, Attention ! "​$e"​ n'est pas plus grand que "​$f"​  +
- mais après "​$f"​ selon l'​ordre des caractères ASCII !!!" +
-fi +
-</​code>​ +
-Retour: ​ 8-O+
  
->​Remarquez l'​incohérence : ''​23 > 24''​ +Nous créons ici une fonction ​(test_si_négatifqui teste si une expression numérique ou arithmétique est négative.
->Il s'agit de tests sur les chaînes de caractères,​ donc il ne s'agit pas de plus petit +
->ou de plus grand, mais d'​avant et après, selon l'​ordre des caractères ''​ASCII''​(([[doc:​programmation:​shells:​bash-vii-globs-etendus-regex#​index-2]])).+
  
->De mêmeattention 26 n'est pas plus grand que 25 ! +__Rappel :__ La commande **return** est identique à la commande **exit** (return s'​utilise dans une fonctionexit dans un script).
->Mais 26 est après 25.+
  
-</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 négatif 
 + then #​ Si oui, 
 + rc=1 #​ Affecte 1 au paramètre rc 
 + elif (($1 < 0)) # Si non, test si l'​argument est positif 
 + then #​ Si oui, 
 + rc=0 #​ Affecte 0 au paramètre rc 
 + fi  
 + return $rc # Affecte $rc au code retour 
 +}
  
 +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>​
 +1
 +0
 +0
 +</​file>​
 ===== Comparaison numérique avec [ et [[ ===== ===== Comparaison numérique avec [ et [[ =====
 La comparaison numérique peut aussi se réalisée avec les commandes **[** (ou **test**) et **<​nowiki>​[[</​nowiki>​**. La comparaison numérique peut aussi se réalisée avec les commandes **[** (ou **test**) et **<​nowiki>​[[</​nowiki>​**.
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