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:la-page-man-bash-ii-les-operateurs-lexicographiques [13/02/2023 17:48] agp91 [Tests sur les fichiers] |
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [21/02/2023 00:01] agp91 [Opérateurs numériques] |
||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
- | ======Bash : les opérateurs lexicographiques ====== | ||
- | * Objet : suite de la série de wiki visant à maîtriser bash via les différents caractère spéciaux. | + | ====== Bash : Les opérateurs de test sur chaînes ====== |
+ | |||
+ | * Objet : Suite de la série de wiki visant à maîtriser bash via les caractères. | ||
* Niveau requis : {{tag>débutant avisé}} | * Niveau requis : {{tag>débutant avisé}} | ||
+ | * 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=140699#p140699 | 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=140699#p140699 | Lien vers le forum concernant ce tuto]] ((N'hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !)) | ||
* [[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]] | ||
- | * ;-) | + | * [[atelier:chantier:bash:les-operateurs-sur-parametres|Les opérateurs de test sur paramètres]] |
+ | * **Les opérateurs de test sur chaînes** ;-) | ||
+ | * [[atelier:chantier:bash:les-operateurs-de-test-sur-fichiers|Les opérateurs de test sur fichiers]] | ||
* [[doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique|Les opérateurs de comparaison numérique]] | * [[doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique|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-iv-symboles-dans-les-calculs-mathematiques|Les symboles dans les calculs]] | ||
Ligne 18: | Ligne 24: | ||
* [[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 ===== | ||
- | ===== Caractères de comparaison sur les chaînes de caractères ===== | + | En interne, bash dispose de plusieurs commandes pour réaliser des tests sur des paramètres, des chaînes de caractères, des fichiers ou encore faire des comparaison numériques : |
- | * Le shell bash utilise les opérateurs booléens sur les chaînes de caractère : ''=='', ''!='' , ''<'' , ''>'' et ''='' , | + | *Les commandes **[** et **test**. |
- | * contexte : conditions voir man bash | + | *Et la commande composée **<nowiki>[[</nowiki>**. |
- | ^ Condition ^ Signification ^ | + | Les commandes **[** et **test** sont disponibles dans leurs versions externe : **/usr/bin/[** et **/usr/bin/test**.\\ |
- | |$chaine1 ''= ''$chaine2 | correspond à | | + | Elles ont toutes les deux la même page de manuel (**man [** ou **man test**).\\ |
- | |$chaîne1 ''=='' $chaîne2 | synonyme de = | | + | Les commandes internes disposent des opérateurs que n'ont pas les commandes externes. |
- | |$chaine1 ''!='' $chaine2 | ne correspond pas | | + | |
- | |$chaine1 ''<'' $chaîne2 | vrai si chaine1 est placée lexicographiquement avant chaine2 | | + | |
- | |$chaine1 ''>'' $chaîne2 | vrai si chaine2 est placée lexicographiquement après chaine2 | | + | |
+ | __Rappels :__ | ||
+ | * Une commande de test renvoie le code de retour **0** (considérer comme vrai) lorsque le test réussi et **1** (considérer comme faux) lorsqu'il échoue. | ||
+ | * Le code retour d'une commande est mémorisé dans le paramètre spécial **$?**. | ||
+ | * L'opérateur **<nowiki>&&</nowiki>** exécute la commande suivante, si la commande précédente à renvoyée un code de retour égale à 0. | ||
+ | * L'opérateur **<nowiki>||</nowiki>** exécute la commande suivante, si la commande précédente à renvoyée un code de retour supérieur à 0. | ||
- | > Le shell bash utilise les commandes internes et composées ''<nowiki>[[ ]]</nowiki>'' ou ''[ ]'' (souvent utilisées avec ''if'') pour les comparaisons de chaînes de caractères. | ||
- | C'est pourquoi on trouve souvent les options ''-z'' et ''-n'' du tableau ci-dessous, ajoutées au tableau ci-dessus : | + | ===== Opérateurs sur les chaînes ===== |
- | ^ Condition ^ Signification ^ | + | |
- | |''-z'' $chaine | ne contient rien | | + | ==== Tester une chaîne (vide ou pas) ==== |
- | |''-n'' $chaine | contient quelque-chose | | + | |
+ | Les commandes de test disposent de deux opérateurs unaires pour tester si une chaîne est vide (de longueur nulle) ou pas. | ||
+ | |||
+ | Syntaxe : | ||
+ | <code> | ||
+ | test OP chaîne | ||
+ | [ OP chaîne ] | ||
+ | [[ OP chaîne ]] | ||
+ | |||
+ | Chaîne est sujette au développement des paramètres. | ||
+ | Avec pour OP, l'un des opérateur du tableau suivant. | ||
+ | </code> | ||
+ | |||
+ | Si l'opérande contient des espaces, il doit être protégé. | ||
+ | |||
+ | | Opérateurs de test sur chaîne || | ||
+ | ^ Opérateurs ^ Retours ^ | ||
+ | |''-z'' | Vrai si chaîne de longueur nulle | | ||
+ | |''-n'' | Vrai si chaîne de longueur non nulle | | ||
+ | |||
+ | L'opérateur **-n** peut-être omis. | ||
+ | |||
+ | === Exemples dans un terminal === | ||
+ | |||
+ | <code user> | ||
+ | test -z ; echo $? #Test si vide et affiche le code retour | ||
+ | [ -n "" ] ; echo $? #Test si non vide et affiche le code retour | ||
+ | [[ "" ]] ; echo $? #Test si non vide et affiche le code retour | ||
+ | </code> | ||
+ | <file config Retour des commandes> | ||
+ | 0 | ||
+ | 1 | ||
+ | 1 | ||
+ | </file> | ||
+ | |||
+ | <code user> | ||
+ | test -z "mot" ; echo $? | ||
+ | [[ -n "Linux" ]] ; echo $? | ||
+ | [[ "GNU Linux" ]] ; echo $? | ||
+ | </code> | ||
+ | <file config Retour des commandes> | ||
+ | 1 | ||
+ | 0 | ||
+ | 0 | ||
+ | </file> | ||
+ | |||
+ | <code user> | ||
+ | v="Debian GNU Linux" | ||
+ | test -z "$v" ; echo $? | ||
+ | |||
+ | v="" | ||
+ | [ -n "$v" ] ; echo $? | ||
+ | |||
+ | unset v # Supprime le paramètre v | ||
+ | [[ -z "$v" ]] ; echo $? | ||
+ | [ "$v" ] ; echo $? | ||
+ | |||
+ | </code> | ||
+ | <file config Retour des commandes> | ||
+ | 1 | ||
+ | 0 | ||
+ | 0 | ||
+ | 1 | ||
+ | </file> | ||
+ | |||
+ | === Mauvais usages === | ||
+ | |||
+ | Les opérateurs **-z** et **-n** sont des opérateurs unaires, il n'accepte qu'un seul opérande (argument).\\ | ||
+ | Si sa valeur contient des espaces, il doit être protégé par des guillemets doubles. | ||
+ | |||
+ | <code> | ||
+ | p="Debian Facile" | ||
+ | test -z $p ; echo $? | ||
+ | |||
+ | unset p | ||
+ | </code> | ||
+ | <file config Retour des commandes> | ||
+ | bash: test: Debian : opérateur binaire attendu | ||
+ | 2 | ||
+ | </file> | ||
+ | |||
+ | __Rappel :__ Lorsqu'une commande interne renvoie un code de retour 2, cela signifie un mauvais usage de cette commande. | ||
+ | |||
+ | L'opérateur **-n** revoie un code de retour inattendu, quand un paramètre vide est testé sans protection.\\ | ||
+ | Sauf avec la commande **<nowiki>[[</nowiki>**. | ||
+ | |||
+ | <code> | ||
+ | test -n $p ; echo $? | ||
+ | [ -n $p ] ; echo $? | ||
+ | |||
+ | p="" | ||
+ | [[ -n $p ]] ; echo $? | ||
+ | |||
+ | unset p | ||
+ | </code> | ||
+ | <file> | ||
+ | 0 | ||
+ | 0 | ||
+ | 1 | ||
+ | </file> | ||
+ | |||
+ | === Astuces === | ||
+ | |||
+ | Avec l'opérateur **-z**, nous pouvons nous affranchir de la protection des guillemets en utilisant **le remplacement des paramètre** et l'opérateur **+**.\\ | ||
+ | (Voir [[https://debian-facile.org/doc:programmation:shells:man-bash-vi-les-caracteres-de-transformation-de-parametres#substitution-par-modification|Substitution de la valeur d'un paramètre]]) | ||
+ | <code> | ||
+ | p="Debian GNU Linux" | ||
+ | |||
+ | test -z ${p+x} ; echo $? | ||
+ | |||
+ | unset p | ||
+ | [[ -z ${p+x} ]] ; echo $? | ||
+ | </code> | ||
+ | <file config Retour de la commande> | ||
+ | 1 | ||
+ | 0 | ||
+ | </file> | ||
+ | |||
+ | Lors du développement (remplacement) d'un paramètre, l’opérateur **+** permet, si la valeur du paramètre est non nulle, de la substituée par une autre valeur (ici x). | ||
+ | |||
+ | Avec l'opérateur **-n** les guillemets restent nécessaires au cas ou le paramètre mémorise une chaîne vide, sauf avec la commande **<nowiki>[[</nowiki>**. | ||
+ | |||
+ | <code> | ||
+ | p="Debian Facile" | ||
+ | |||
+ | [[ -n ${p+x} ]] ; echo $? | ||
+ | [[ -${p+x} ]] ; echo $? | ||
+ | |||
+ | unset p | ||
+ | [[ -n ${p+x} ]] ; echo $? | ||
+ | [[ -${p+x} ]] ; echo $? | ||
+ | </code> | ||
+ | <file config Retour de la commande> | ||
+ | 0 | ||
+ | 0 | ||
+ | 1 | ||
+ | 1 | ||
+ | </file> | ||
+ | |||
+ | ==== Comparaison de chaînes ==== | ||
+ | |||
+ | Les commandes de test disposent d'opérateurs binaires pour comparer deux chaînes entre elles. | ||
+ | |||
+ | Syntaxe : | ||
+ | <code> | ||
+ | test chaîne1 OP chaîne2 | ||
+ | [ chaîne1 OP chaîne2 ] | ||
+ | [[ chaîne1 OP chaîne2 ]] | ||
+ | |||
+ | Chaîne1 et chaîne2 sont sujettes au développement des paramètres. | ||
+ | Avec pour OP, l'un des opérateur du tableau suivant. | ||
+ | </code> | ||
+ | |||
+ | Si un opérande (chaîne1 ou chaîne2) est une chaîne vide, ou contient des espaces, il doit être protégé, placé entre guillemets simples ou doubles. | ||
+ | |||
+ | | Opérateurs de comparaison sur les chaînes || | ||
+ | ^ Opérateurs ^ Significations ^ | ||
+ | | ''= '' | Correspond à | | ||
+ | | ''=='' | Synonyme de = | | ||
+ | | ''!='' | Ne correspond pas | | ||
+ | | ''<'' | Vrai si chaine1 est placée lexicographiquement avant chaine2 | | ||
+ | | ''>'' | Vrai si chaine2 est placée lexicographiquement après chaine2 | | ||
+ | |||
+ | === Exemples dans un terminal === | ||
<note important> | <note important> | ||
Ligne 55: | Ligne 226: | ||
</note> | </note> | ||
- | ==== Remarques ==== | ||
- | * Dans le terminal, crochets ou commande test: | ||
<code user> | <code user> | ||
- | test1= | + | test "GNU" == "GNU" ] ; echo $? |
- | #puis | + | [[ "GNU" != "GNU Linux" ]] ; echo $? |
- | [ -n "$test1" ] | + | </code> |
- | #puis | + | <file config Retour des commandes> |
- | echo $? | + | 0 |
+ | 0 | ||
+ | </file> | ||
+ | |||
+ | >Donc la chaîne "GNU" est identique à elle-même ;), mais pas à "GNU Linux". | ||
+ | |||
+ | <code user> | ||
+ | v1="Debian GNU Linux" | ||
+ | v2="Debian Facile" | ||
+ | if [ "$v1" = "$v2" ] | ||
+ | then | ||
+ | echo 'vrai' | ||
+ | else | ||
+ | echo 'faux' | ||
+ | fi | ||
+ | |||
+ | unset v1 v2 | ||
</code> | </code> | ||
<file config retour de la commande> | <file config retour de la commande> | ||
- | 1 | + | faux |
</file> | </file> | ||
- | >Donc la chaîne de la variable test1 est égale à zéro. | + | >Donc les deux chaînes contenues dans les variables v1 et v2 ne sont pas égales. |
- | * Autre exemple : | + | === Mauvais usages === |
+ | |||
+ | Les deux opérandes sont obligatoires. | ||
<code user> | <code user> | ||
- | test2=abc | + | test GNU == ; echo $? |
- | #puis | + | [[ != LINUX ]] |
- | test3=ab | + | |
- | #puis | + | |
- | [ "$test2" = "$test3" ] | + | |
- | #puis | + | |
echo $? | echo $? | ||
</code> | </code> | ||
- | <file config retour de la commande> | + | <file Retour de la commande> |
- | 1 | + | echo $? |
+ | bash: test: GNU : opérateur unaire attendu | ||
+ | 2 | ||
+ | bash: opérateur binaire conditionnel attendu | ||
+ | bash: erreur de syntaxe près de « LINUX » | ||
+ | 2 | ||
</file> | </file> | ||
- | >Donc les deux chaînes de valeur contenue dans les variables test2 et test3 ne sont pas égales. | + | Les espaces entre les opérandes et l'opérateur sont obligatoires. |
- | * Dans les scripts, c'est pareil ! ;-) | + | <code user> |
- | Tests avec les crochets : | + | [ "GNU Linux"=="LINUX" ] ; echo $? |
+ | </code> | ||
+ | <file Retour de la commande> | ||
+ | 0 | ||
+ | </file> | ||
+ | |||
+ | Sans espace entre les opérande et l'opérateur "GNU Linux"=="LINUX" est compris comme une chaîne de caractère.\\ | ||
+ | N'étant pas nulle, le test n'échoue pas. | ||
+ | |||
+ | === Exemples dans un script === | ||
+ | |||
+ | Copions le code suivant dans le fichier mon_script. | ||
- | <code bash mon-script> | + | <code bash mon_script> |
#!/bin/bash | #!/bin/bash | ||
var1="def" | var1="def" | ||
var2="def" | var2="def" | ||
- | if [ $var1 == $var2 ] ; then | + | if [ "$var1" == "$var2" ] ; then |
- | echo "1)test de correspondance chaîne de caractères sur valeur de variable: \$var1:"$var1" correspond(==) à \$var2:"$var2"." | + | echo "1) \$var1 ($var1) correspond(==) à \$var2 ($var2)." |
fi | fi | ||
var3="hip" | var3="hip" | ||
var4="hip" | var4="hip" | ||
- | if test $var3 = $var4 ; then | + | if test "$var3" = "$var4" ; then |
- | echo "2) test de correspondance chaîne de caractères sur valeur de variable: \$var3:"$var3" correspond(=) à \$var4:"$var4"." | + | echo "2) \$var3 ($var3) correspond(=) à \$var4 ($var4)." |
fi | fi | ||
</code> | </code> | ||
<code user> | <code user> | ||
- | ./mon-script | + | bash mon_script |
- | </code> | + | |
- | <file config retour de la commande> | + | rm -v mon_script |
- | 1) test de correspondance chaîne de caractères sur valeur de variable: $var1:def correspond(==) à $var2:def. | + | |
- | 2) test de correspondance chaîne de caractères sur valeur de variable: $var3:hip correspond(=) à $var4:hip. | + | |
- | </file> | + | |
- | + | ||
- | Tests avec la commande test : | + | |
- | + | ||
- | <code user> | + | |
- | test4=tout-compris | + | |
- | #puis | + | |
- | test5=toutcompris | + | |
- | #puis | + | |
- | test $test4 = $test5 | + | |
- | #puis | + | |
- | echo $? | + | |
</code> | </code> | ||
- | + | <file config Retour de la commande> | |
- | <file config retour de la commande> | + | 1) $var1 (def) correspond(==) à $var2 (def). |
- | 1 | + | 2) $var3 (hip) correspond(=) à $var4 (hip). |
+ | 'mon_script' supprimé | ||
</file> | </file> | ||
- | >Donc les chaînes des deux valeurs sont différentes. | + | Les commandes de test permettent de réaliser des test de comparaison lexicographique.\\ |
+ | (voir [[https://debian-facile.org/atelier:chantier:bash-comparaison-lexicographique-des-chaines|https://debian-facile.org/atelier:chantier:bash-comparaison-lexicographique-des-chaines]].) | ||
<note important> | <note important> | ||
- | Attention de ne pas confondre les opérateurs de comparaison sur les chaînes de caractère avec les [[https://debian-facile.org/doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique#operateurs-booleens-de-comparaison-numerique|opérateurs booléens de comparaison numérique]] qui utilisent les mêmes symboles (mais avec la syntaxe doubles parenthèses et surtout pas de crochets).\\ | + | Attention de ne pas confondre les opérateurs de comparaison sur les chaînes de caractère avec les [[https://debian-facile.org/doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique#operateurs-booleens-de-comparaison-numerique|opérateurs de comparaison numérique]] qui utilisent les mêmes symboles (mais avec la syntaxe doubles parenthèses et surtout pas de crochets).\\ |
</note> | </note> | ||
Ligne 158: | Ligne 344: | ||
Les opérateurs \< et \> signifient avant et après selon l'ordre alphabétique (simples crochets) | Les opérateurs \< et \> signifient avant et après selon l'ordre alphabétique (simples crochets) | ||
</file> | </file> | ||
+ | |||
+ | Avec les commandes **[** ou **test**, les opérateur **<** et **>** doivent être protégés.\\ | ||
+ | (Voir [[https://debian-facile.org/atelier:chantier:bash-comparaison-lexicographique-des-chaines#tests-avec1|Comparaison lexicographique avec [ ou test.]]) | ||
Ligne 168: | Ligne 357: | ||
</code> | </code> | ||
- | |Extrait du manpage de bash section CONDITIONS|| | + | |Extrait de la page du manuel de bash section CONDITIONS|| |
^ Opérateurs ^ Retours : ^ | ^ Opérateurs ^ Retours : ^ | ||
|-a fichier |Vrai si le fichier existe.| | |-a fichier |Vrai si le fichier existe.| | ||
Ligne 195: | Ligne 384: | ||
|fichier_1 -ot fichier_2 |Vrai si le fichier_1 est plus ancien que le fichier_2 ou si fichier_2 existe et non fichier_1.| | |fichier_1 -ot fichier_2 |Vrai si le fichier_1 est plus ancien que le fichier_2 ou si fichier_2 existe et non fichier_1.| | ||
- | Remarque : L'opérateur -e test si le fichier existe quelque soit son statut (fichier, répertoire, lien, etc). | + | Remarque : L'opérateur **-e** teste si le fichier existe quelque soit son statut (fichier, répertoire, lien, etc). |
- | ==== Test dans script ==== | + | ==== Test dans un script ==== |
Soit le script mon_script. | Soit le script mon_script. | ||
<code bash script> | <code bash script> |