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 →
Ci-dessous, les différences entre deux révisions de la page.
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 [14/02/2023 08:24] agp91 [Introduction] |
doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique [14/02/2023 16:25] agp91 [Comparaison numérique avec ((] |
||
---|---|---|---|
Ligne 23: | Ligne 23: | ||
===== Introduction ===== | ===== Introduction ===== | ||
- | Bash dispose de deux types de commandes pour réaliser des comparaisons numériques: | + | |
- | *La commande composée d'évaluation numérique **<nowiki>((</nowiki>**. | + | Bash dispose de plusieurs commandes pour réaliser des comparaisons numériques: |
- | *La commande composée **<nowiki>[[</nowiki>** et la commande **[** (ou **test**. | + | *La commande composée d'évaluation numérique **<nowiki>((</nowiki>**, |
+ | *La commande **[** (ou **test**), | ||
+ | *Et la commande composée **<nowiki>[[</nowiki>**. | ||
===== Comparaison numérique avec (( ===== | ===== Comparaison numérique avec (( ===== | ||
+ | |||
Syntaxe : | Syntaxe : | ||
- | <code>(( expr opérateur expr ))</code> | + | <code> |
+ | (( 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> | ||
|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 41: | Ligne 50: | ||
- | ==== Exemple dans le terminal ==== | + | ==== Exemples dans le terminal ==== |
<code user> | <code user> | ||
+ | (( 42 == 42 )) # Est-ce que 42 est égale à 42. | ||
+ | echo $? # Affiche le code de retour. | ||
+ | |||
nombre1=12 | nombre1=12 | ||
nombre2=13 | nombre2=13 | ||
- | (( $nombre1 > $nombre2 )) | + | (( $nombre1 > $nombre2 )) # Est-ce-que nombre1 (12) est strictement supérieur au nombre2 (13). |
- | echo $? | + | echo $? # Affiche le code de retour. |
- | unset nombre1 nombre2 | + | unset nombre1 nombre2 # Suppression des paramètres nombre1 et nombre2 |
</code> | </code> | ||
<file config retour de la commande> | <file config retour de la commande> | ||
+ | 0 | ||
1 | 1 | ||
</file> | </file> | ||
Ligne 74: | Ligne 87: | ||
42 > 24 | 42 > 24 | ||
42 est supérieur à 24 | 42 est supérieur à 24 | ||
+ | </file> | ||
+ | |||
+ | 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 caractère $ pour être développé.\\ | ||
+ | Un simple mot sera alors interprété comme un paramètre.\\ | ||
+ | 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). | ||
+ | |||
+ | <code user> | ||
+ | echo ========== | ||
+ | (("Du texte" >= 0)) | ||
+ | echo -e "((\"Du texte\" >= 0)) revoie le code de retour $? \n" | ||
+ | |||
+ | (("DuTexte" == 0)) | ||
+ | echo -e "((\"DuTexte\" == 0)) revoie le code de retour $? \n" | ||
+ | |||
+ | n="Du texte" | ||
+ | ((n>=0)) | ||
+ | echo -e 'Avec n="Du texte" ; ((n>=0)) renvoie le code retour' $? \\n | ||
+ | |||
+ | n="Dutexte" | ||
+ | ((n!=0)) | ||
+ | echo -e 'Avec n="DuTexte" ; ((n!=0)) renvoie le code retour' $? \\n | ||
+ | |||
+ | 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)) revoie le code de retour 1 | ||
+ | |||
+ | (("DuTexte" == 0)) revoie le code de retour 0 | ||
+ | |||
+ | bash: ((: Du texte : erreur de syntaxe dans l'expression (le symbole erroné est « texte ») | ||
+ | Avec n="Du texte" ; ((n>=0)) renvoie le code retour 1 | ||
+ | |||
+ | Avec n="DuTexte" ; ((n!=0)) renvoie le code retour 1 | ||
</file> | </file> | ||
==== 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 82: | 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=4 | + | |
- | 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égatif) qui 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ême, attention 26 n'est pas plus grand que 25 ! | + | __Rappel :__ La commande **return** est identique à la commande **exit** (return s'utilise dans une fonction, exit 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>**. |
Syntaxe : | Syntaxe : | ||
Ligne 157: | Ligne 222: | ||
- | ===Exemple dans le terminal === | + | ===Exemples dans le terminal === |
<code user> | <code user> | ||
[ 25 -eq 20 ] | [ 25 -eq 20 ] |