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 [16/02/2023 18:40] agp91 [Comparaison de chaînes] |
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [16/02/2023 22:42] agp91 [Opérateurs sur chaîne(s)] |
||
---|---|---|---|
Ligne 22: | Ligne 22: | ||
===== Introduction ===== | ===== Introduction ===== | ||
- | En interne, bash dispose de plusieurs commandes pour réaliser des tests sur les chaînes : | + | 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 : |
*Les commandes **[** et **test**. | *Les commandes **[** et **test**. | ||
*Et la commande composée **<nowiki>[[</nowiki>**. | *Et la commande composée **<nowiki>[[</nowiki>**. | ||
Ligne 31: | Ligne 31: | ||
__Rappels :__ | __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. | + | * 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 **$?**. | * 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 égale à 0. | ||
Ligne 37: | Ligne 37: | ||
- | ===== Test sur chaîne (vide ou pas) ===== | + | ===== Opérateurs sur chaîne(s) ===== |
- | Les commandes de test disposent d'opérateurs unaires pour tester si une chaîne est vide (de longueur nulle) ou pas. | + | ==== Tester une chaîne (vide ou pas) ==== |
+ | |||
+ | Les commandes de test disposent de deux opérateurs unaires pour tester si une chaîne est vide (de longueur nulle) ou pas. | ||
Syntaxe : | Syntaxe : | ||
Ligne 57: | Ligne 59: | ||
|''-n'' | Chaîne de longueur non nulle | | |''-n'' | Chaîne de longueur non nulle | | ||
- | ===== Comparaison de chaînes ===== | + | === Exemples === |
+ | |||
+ | <code user> | ||
+ | test -z ; echo $? #Test si vide et affiche le code retour | ||
+ | [ -n "" ] ; echo $? #Test si non vide et affiche le code retour | ||
+ | [[ -z "" ]] ; echo $? #Test si vide et affiche le code retour | ||
+ | </code> | ||
+ | <file config Retour des commandes> | ||
+ | 0 | ||
+ | 1 | ||
+ | 0 | ||
+ | </file> | ||
+ | |||
+ | <code user> | ||
+ | test -z "mot" ; echo $? | ||
+ | [ -n "Linux" ] ; echo $? | ||
+ | [[ -z "GNU Linux" ]] ; echo $? | ||
+ | </code> | ||
+ | <file config Retour des commandes> | ||
+ | 1 | ||
+ | 0 | ||
+ | 1 | ||
+ | </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 $? | ||
+ | |||
+ | </code> | ||
+ | <file config Retour des commandes> | ||
+ | 1 | ||
+ | 0 | ||
+ | 0 | ||
+ | </file> | ||
+ | |||
+ | === Mauvais usages === | ||
+ | |||
+ | Les opérateurs **-z** et **-n** sont des opérateurs unaires, il n'accepte qu'un seul opérande (argument).\\ | ||
+ | Ne pas protéger par des guillemets doubles, un paramètre testé, provoque une erreur, si sa valeur contient des espaces. | ||
+ | <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> | ||
+ | |||
+ | <note> | ||
+ | Lorsqu'une commande interne renvoie un code de retour 2, cela signifie un mauvais usage de cette commande. | ||
+ | </note> | ||
+ | |||
+ | Avec la commande **[** ou **test**, l'opérateur **-n** revoie un code de retour inattendu, quand un paramètre vide est testé sans protection. | ||
+ | <code> | ||
+ | test -n $p ; echo $? | ||
+ | [ -n $p ] ; echo $? | ||
+ | |||
+ | p="" | ||
+ | [[ -n $p ]] ; echo $? | ||
+ | |||
+ | unset p | ||
+ | </code> | ||
+ | <file> | ||
+ | 0 | ||
+ | 0 | ||
+ | 1 | ||
+ | </file> | ||
+ | |||
+ | === Bon usage === | ||
+ | |||
+ | 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 $? | ||
+ | [ -z ${p+x} ] ; echo $? | ||
+ | [[ -z ${p+x} ]] ; echo $? | ||
+ | |||
+ | unset p | ||
+ | </code> | ||
+ | <file config Retour de la commande> | ||
+ | 1 | ||
+ | 1 | ||
+ | 1 | ||
+ | </file> | ||
+ | Lors du développement (remplacement) d'un paramètre, l’opérateur **+** permet si la valeur du paramètre est non nul 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. | ||
+ | |||
+ | ==== Comparaison de chaînes ==== | ||
Les commandes de test disposent d'opérateurs binaires pour comparer deux chaînes entre elles. | Les commandes de test disposent d'opérateurs binaires pour comparer deux chaînes entre elles. | ||
Ligne 80: | Ligne 179: | ||
| ''<'' | Vrai si chaine1 est placée lexicographiquement avant chaine2 | | | ''<'' | Vrai si chaine1 est placée lexicographiquement avant chaine2 | | ||
| ''>'' | Vrai si chaine2 est placée lexicographiquement après chaine2 | | | ''>'' | Vrai si chaine2 est placée lexicographiquement après chaine2 | | ||
+ | |||
+ | === Exemples === | ||
<note important> | <note important> | ||
Ligne 97: | Ligne 198: | ||
</note> | </note> | ||
- | ==== Remarques ==== | ||
- | * Dans le terminal, crochets ou commande test: | ||
<code user> | <code user> | ||
test1= | test1= | ||
- | #puis | ||
[ -n "$test1" ] | [ -n "$test1" ] | ||
- | #puis | ||
echo $? | echo $? | ||
+ | |||
+ | unset test1 | ||
</code> | </code> | ||
- | <file config retour de la commande> | + | <file config Retour de la commande> |
1 | 1 | ||
</file> | </file> | ||
>Donc la chaîne de la variable test1 est égale à zéro. | >Donc la chaîne de la variable test1 est égale à zéro. | ||
- | |||
- | * Autre exemple : | ||
<code user> | <code user> | ||
test2=abc | test2=abc | ||
- | #puis | ||
test3=ab | test3=ab | ||
- | #puis | ||
[ "$test2" = "$test3" ] | [ "$test2" = "$test3" ] | ||
- | #puis | ||
echo $? | echo $? | ||
+ | |||
+ | unset test2 test3 | ||
</code> | </code> | ||
<file config retour de la commande> | <file config retour de la commande> | ||
Ligne 127: | Ligne 223: | ||
</file> | </file> | ||
- | >Donc les deux chaînes de valeur contenue dans les variables test2 et test3 ne sont pas égales. | + | >Donc les deux chaînes contenue dans les variables test2 et test3 ne sont pas égales. |
- | * Dans les scripts, c'est pareil ! ;-) | + | === Exemples dans un script === |
- | Tests avec les crochets : | + | |
- | <code bash mon-script> | + | <code bash mon_script> |
#!/bin/bash | #!/bin/bash | ||
var1="def" | var1="def" | ||
Ligne 148: | Ligne 243: | ||
<code user> | <code user> | ||
- | ./mon-script | + | bash mon-script |
- | </code> | + | |
+ | rm -v mon_script | ||
+ | </code> | ||
<file config retour de la commande> | <file config retour de la commande> | ||
1) test de correspondance chaîne de caractères sur valeur de variable: $var1:def correspond(==) à $var2:def. | 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. | 2) test de correspondance chaîne de caractères sur valeur de variable: $var3:hip correspond(=) à $var4:hip. | ||
+ | 'mon_script' supprimé | ||
</file> | </file> | ||
- | |||
- | Tests avec la commande test : | ||
- | |||
- | <code user> | ||
- | test4=tout-compris | ||
- | #puis | ||
- | test5=toutcompris | ||
- | #puis | ||
- | test $test4 = $test5 | ||
- | #puis | ||
- | echo $? | ||
- | </code> | ||
- | |||
- | <file config retour de la commande> | ||
- | 1 | ||
- | </file> | ||
- | |||
- | >Donc les chaînes des deux valeurs sont différentes. | ||
<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> | ||