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 [21/02/2023 00:13] agp91 [Bash : Les opérateurs de test sur chaînes] |
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [21/02/2023 00:29] agp91 [Introduction] |
||
---|---|---|---|
Ligne 25: | Ligne 25: | ||
===== Introduction ===== | ===== Introduction ===== | ||
- | |||
<note> | <note> | ||
Ligne 51: | Ligne 50: | ||
</note> | </note> | ||
- | Les commandes de test disposent de 5 primitives binaires pour comparer deux chaînes entre elles. | + | ===== 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 ==== | ||
- | * **test chaîne1 OP chaîne2** | + | * **test OP chaîne** |
- | * **[ chaîne1 OP chaîne2 ]** | + | * **[ OP chaîne ]** |
- | * **<nowiki>[[</nowiki> chaîne1 OP chaîne2 <nowiki>]]</nowiki>** | + | * **<nowiki>[[</nowiki> OP chaîne <nowiki>]]</nowiki>** |
* Avec : | * Avec : | ||
- | * **Chaîne1** et **chaîne2** sont sujettes au développement des paramètres. | + | * **Chaîne** est sujette au développement des paramètres. |
- | * **OP**, l'un des opérateur du tableau suivant. | + | * **OP**, l'une des primitives du tableau suivant. |
<note> | <note> | ||
- | Si un opérande (**chaîne1** ou **chaîne**2) est une chaîne vide, ou contient des espaces,\\ | + | Si l'opérande (**chaîne**) contient des espaces, il doit être protégé. |
- | Il doit être protégé, placé entre guillemets simples ou doubles. | + | |
</note> | </note> | ||
- | | Listes des primitives de comparaison entre deux chaînes || | + | | Liste des primitives de test sur chaîne || |
- | ^ Primitives ^ Retours ^ | + | ^ Primitives ^ Retours ^ |
- | | ''= '' | Vrai si **Chaîne1** correspond à **Chaîne2** . | | + | |
- | | ''=='' | Synonyme de **=** | | + | |
- | | ''!='' | Vrai si **Chaîne1** ne correspond pas à **Chaîne2**. | | + | |
- | | ''<'' | Vrai si **chaine1** est placée lexicographiquement avant **chaine2** | | + | |
- | | ''>'' | Vrai si **chaine1** est placée lexicographiquement après **chaine2** | | + | |
- | + | ||
- | ==== Exemples ==== | + | |
- | + | ||
- | <note important> | + | |
- | __-bashismes :__ | + | |
- | <code> | + | |
- | [[ $a == "z*" ]] # vrai si $a est égal à z* | + | |
- | [[ $a == z* ]] # vrai si $a commence avec un "z" (reconnaissance de modèles) | + | |
- | [[ "$a" < "$b" ]] # vrai si $a se trouve avant $b dans le dictionnaire | + | |
- | </code> | + | |
- | __-posix :__ | + | |
- | + | ||
- | <code> | + | |
- | [ "$a" = "z*" ] # vrai si $a est égal à z* | + | |
- | [ "$a" \< "$b" ] # vrai si $a se trouve avant $b dans le dictionnaire | + | |
- | </code> | + | |
- | </note> | + | |
- | + | ||
- | <code user> | + | |
- | test "GNU" == "GNU" ] ; echo $? | + | |
- | [[ "GNU" != "GNU Linux" ]] ; echo $? | + | |
- | </code><file> | + | |
- | 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><file> | + | |
- | faux | + | |
- | </file> | + | |
- | + | ||
- | >Donc les deux chaînes contenues dans les variables v1 et v2 ne sont pas égales. | + | |
- | + | ||
- | Copions le code suivant dans le fichier **mon_script**. | + | |
- | + | ||
- | <code bash mon_script> | + | |
- | #!/bin/bash | + | |
- | var1="def" | + | |
- | var2="def" | + | |
- | if [ "$var1" == "$var2" ] ; then | + | |
- | echo "1) \$var1 ($var1) correspond(==) à \$var2 ($var2)." | + | |
- | fi | + | |
- | + | ||
- | var3="hip" | + | |
- | var4="hip" | + | |
- | if test "$var3" = "$var4" ; then | + | |
- | echo "2) \$var3 ($var3) correspond(=) à \$var4 ($var4)." | + | |
- | fi | + | |
- | </code><code user> | + | |
- | bash mon_script | + | |
- | + | ||
- | rm -v mon_script | + | |
- | </code><file> | + | |
- | 1) $var1 (def) correspond(==) à $var2 (def). | + | |
- | 2) $var3 (hip) correspond(=) à $var4 (hip). | + | |
- | 'mon_script' supprimé | + | |
- | </file> | + | |
- | + | ||
- | 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> | + | |
- | Attention de ne pas confondre les primitives de comparaison lexicographique sur les chaînes 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 caractères. | + | |
- | </note> | + | |
- | + | ||
- | <code usert> | + | |
- | a="sloiuy" | + | |
- | b="aktgjaùkjayaj" | + | |
- | + | ||
- | if [[ $a < $b ]] ; then | + | |
- | echo "OK l'opérateur < fonctionne avec les chaînes de caractère" | + | |
- | fi | + | |
- | + | ||
- | if [[ $a > $b ]] ; then | + | |
- | echo "Les opérateurs < et > signifient avant et après selon l'ordre alphabétique (doubles crochets) " | + | |
- | fi | + | |
- | + | ||
- | if [ $a \> $b ] ; then | + | |
- | echo "Les opérateurs \< et \> signifient avant et après selon l'ordre alphabétique (simples crochets) " | + | |
- | fi | + | |
- | </code><file> | + | |
- | OK L'opérateur < fonctionne avec les chaînes de caractère | + | |
- | Les opérateurs < et > signifient avant et après selon l'ordre alphabétique (doubles crochets) | + | |
- | Les opérateurs \< et \> signifient avant et après selon l'ordre alphabétique (simples crochets) | + | |
- | </file> | + | |
- | + | ||
- | <note> | + | |
- | Avec les commandes **[** ou **test**, les primitives **<** et **>** doivent être protégées.\\ | + | |
- | (Voir [[https://debian-facile.org/atelier:chantier:bash-comparaison-lexicographique-des-chaines#tests-avec1|Comparaison lexicographique avec [ ou test.]]) | + | |
- | </note> | + | |
- | + | ||
- | ==== Mauvais usages ==== | + | |
- | + | ||
- | Les deux opérandes sont obligatoires. | + | |
- | + | ||
- | <code user> | + | |
- | test GNU == ; echo $? | + | |
- | [[ != LINUX ]] | + | |
- | echo $? | + | |
- | </code><file> | + | |
- | 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> | + | |
- | + | ||
- | Les espaces entre les opérandes et la primitive sont obligatoires. | + | |
- | + | ||
- | <code user> | + | |
- | [ "GNU Linux"=="LINUX" ] ; echo $? | + | |
- | </code><file> | + | |
- | 0 | + | |
- | </file> | + | |
- | + | ||
- | Sans espace entre les opérande et la primitive "GNU Linux"=="LINUX" est compris comme une chaîne de caractère.\\ | + | |
- | N'étant pas nulle, le test n'échoue pas. | + | |
- | + | ||
- | ===== Opérateurs sur les chaînes ===== | + | |
- | + | ||
- | ==== 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 : | + | |
- | <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 | | |''-z'' | Vrai si chaîne de longueur nulle | | ||
|''-n'' | Vrai si chaîne de longueur non nulle | | |''-n'' | Vrai si chaîne de longueur non nulle | | ||
+ | <note> | ||
L'opérateur **-n** peut-être omis. | L'opérateur **-n** peut-être omis. | ||
+ | </note> | ||
- | === Exemples dans un terminal === | + | ==== Exemples ==== |
<code user> | <code user> | ||
Ligne 237: | Ligne 83: | ||
[ -n "" ] ; echo $? #Test si non 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 | [[ "" ]] ; echo $? #Test si non vide et affiche le code retour | ||
- | </code> | + | </code><file> |
- | <file config Retour des commandes> | + | |
0 | 0 | ||
1 | 1 | ||
Ligne 248: | Ligne 93: | ||
[[ -n "Linux" ]] ; echo $? | [[ -n "Linux" ]] ; echo $? | ||
[[ "GNU Linux" ]] ; echo $? | [[ "GNU Linux" ]] ; echo $? | ||
- | </code> | + | </code><file> |
- | <file config Retour des commandes> | + | |
1 | 1 | ||
0 | 0 | ||
Ligne 266: | Ligne 110: | ||
[ "$v" ] ; echo $? | [ "$v" ] ; echo $? | ||
- | </code> | + | </code><file> |
- | <file config Retour des commandes> | + | |
1 | 1 | ||
0 | 0 | ||
Ligne 274: | Ligne 117: | ||
</file> | </file> | ||
- | === Mauvais usages === | + | ==== Mauvais usages ==== |
Les opérateurs **-z** et **-n** sont des opérateurs unaires, il n'accepte qu'un seul opérande (argument).\\ | Les opérateurs **-z** et **-n** sont des opérateurs unaires, il n'accepte qu'un seul opérande (argument).\\ | ||
Ligne 284: | Ligne 127: | ||
unset p | unset p | ||
- | </code> | + | </code><file> |
- | <file config Retour des commandes> | + | |
bash: test: Debian : opérateur binaire attendu | bash: test: Debian : opérateur binaire attendu | ||
2 | 2 | ||
</file> | </file> | ||
- | + | <note> | |
- | __Rappel :__ Lorsqu'une commande interne renvoie un code de retour 2, cela signifie un mauvais usage de cette commande. | + | Lorsqu'une commande interne renvoie un **code de retour 2**, cela signifie un mauvais usage de cette commande. |
+ | </note> | ||
L'opérateur **-n** revoie un code de retour inattendu, quand un paramètre vide est testé sans protection.\\ | L'opérateur **-n** revoie un code de retour inattendu, quand un paramètre vide est testé sans protection.\\ | ||
Ligne 303: | Ligne 146: | ||
unset p | unset p | ||
- | </code> | + | </code><file> |
- | <file> | + | |
0 | 0 | ||
0 | 0 | ||
Ligne 310: | Ligne 152: | ||
</file> | </file> | ||
- | === Astuces === | + | ==== 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 **+**.\\ | 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 **+**.\\ | ||
Ligne 321: | Ligne 163: | ||
unset p | unset p | ||
[[ -z ${p+x} ]] ; echo $? | [[ -z ${p+x} ]] ; echo $? | ||
- | </code> | + | </code><file> |
- | <file config Retour de la commande> | + | |
1 | 1 | ||
0 | 0 | ||
Ligne 340: | Ligne 181: | ||
[[ -n ${p+x} ]] ; echo $? | [[ -n ${p+x} ]] ; echo $? | ||
[[ -${p+x} ]] ; echo $? | [[ -${p+x} ]] ; echo $? | ||
- | </code> | + | </code><file> |
- | <file config Retour de la commande> | + | |
0 | 0 | ||
0 | 0 | ||
Ligne 348: | Ligne 188: | ||
</file> | </file> | ||
- | ==== Comparaison de chaînes ==== | + | ===== Comparaison entre deux chaînes ===== |
- | Les commandes de test disposent d'opérateurs binaires pour comparer deux chaînes entre elles. | + | Les commandes de test disposent de 5 primitives binaires pour comparer deux chaînes entre elles. |
- | Syntaxe : | + | ==== 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. | + | * **test chaîne1 OP chaîne2** |
- | Avec pour OP, l'un des opérateur du tableau suivant. | + | * **[ chaîne1 OP chaîne2 ]** |
- | </code> | + | * **<nowiki>[[</nowiki> chaîne1 OP chaîne2 <nowiki>]]</nowiki>** |
- | 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. | + | * Avec : |
+ | * **Chaîne1** et **chaîne2** sont sujettes au développement des paramètres. | ||
+ | * **OP**, l'un des opérateur du tableau suivant. | ||
- | | Opérateurs de comparaison sur les chaînes || | + | <note> |
- | ^ Opérateurs ^ Significations ^ | + | Si un opérande (**chaîne1** ou **chaîne**2) est une chaîne vide, ou contient des espaces,\\ |
- | | ''= '' | Correspond à | | + | Il doit être protégé, placé entre guillemets simples ou doubles. |
- | | ''=='' | Synonyme de = | | + | </note> |
- | | ''!='' | 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 === | + | | Listes des primitives de comparaison entre deux chaînes || |
+ | ^ Primitives ^ Retours ^ | ||
+ | | ''= '' | Vrai si **Chaîne1** correspond à **Chaîne2** . | | ||
+ | | ''=='' | Synonyme de **=** | | ||
+ | | ''!='' | Vrai si **Chaîne1** ne correspond pas à **Chaîne2**. | | ||
+ | | ''<'' | Vrai si **chaine1** est placée lexicographiquement avant **chaine2** | | ||
+ | | ''>'' | Vrai si **chaine1** est placée lexicographiquement après **chaine2** | | ||
+ | |||
+ | ==== Exemples ==== | ||
<note important> | <note important> | ||
Ligne 381: | Ligne 224: | ||
[[ "$a" < "$b" ]] # vrai si $a se trouve avant $b dans le dictionnaire | [[ "$a" < "$b" ]] # vrai si $a se trouve avant $b dans le dictionnaire | ||
</code> | </code> | ||
- | __ | + | __-posix :__ |
- | -posix :__ | + | |
<code> | <code> | ||
Ligne 393: | Ligne 235: | ||
test "GNU" == "GNU" ] ; echo $? | test "GNU" == "GNU" ] ; echo $? | ||
[[ "GNU" != "GNU Linux" ]] ; echo $? | [[ "GNU" != "GNU Linux" ]] ; echo $? | ||
- | </code> | + | </code><file> |
- | <file config Retour des commandes> | + | |
0 | 0 | ||
0 | 0 | ||
Ligne 412: | Ligne 253: | ||
unset v1 v2 | unset v1 v2 | ||
- | </code> | + | </code><file> |
- | <file config retour de la commande> | + | |
faux | faux | ||
</file> | </file> | ||
Ligne 419: | Ligne 259: | ||
>Donc les deux chaînes contenues dans les variables v1 et v2 ne sont pas égales. | >Donc les deux chaînes contenues dans les variables v1 et v2 ne sont pas égales. | ||
- | === Mauvais usages === | + | Copions le code suivant dans le fichier **mon_script**. |
- | + | ||
- | Les deux opérandes sont obligatoires. | + | |
- | + | ||
- | <code user> | + | |
- | test GNU == ; echo $? | + | |
- | [[ != LINUX ]] | + | |
- | echo $? | + | |
- | </code> | + | |
- | <file Retour de la commande> | + | |
- | 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> | + | |
- | + | ||
- | Les espaces entre les opérandes et l'opérateur sont obligatoires. | + | |
- | + | ||
- | <code user> | + | |
- | [ "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> | ||
Ligne 466: | Ligne 274: | ||
echo "2) \$var3 ($var3) correspond(=) à \$var4 ($var4)." | echo "2) \$var3 ($var3) correspond(=) à \$var4 ($var4)." | ||
fi | fi | ||
- | </code> | + | </code><code user> |
- | + | ||
- | <code user> | + | |
bash mon_script | bash mon_script | ||
rm -v mon_script | rm -v mon_script | ||
- | </code> | + | </code><file> |
- | <file config Retour de la commande> | + | |
1) $var1 (def) correspond(==) à $var2 (def). | 1) $var1 (def) correspond(==) à $var2 (def). | ||
2) $var3 (hip) correspond(=) à $var4 (hip). | 2) $var3 (hip) correspond(=) à $var4 (hip). | ||
Ligne 483: | Ligne 288: | ||
<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 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 primitives de comparaison lexicographique sur les chaînes 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 caractères. |
</note> | </note> | ||
- | <code bash script> | + | <code usert> |
- | #!/bin/bash | + | |
a="sloiuy" | a="sloiuy" | ||
b="aktgjaùkjayaj" | b="aktgjaùkjayaj" | ||
+ | |||
if [[ $a < $b ]] ; then | if [[ $a < $b ]] ; then | ||
echo "OK l'opérateur < fonctionne avec les chaînes de caractère" | echo "OK l'opérateur < fonctionne avec les chaînes de caractère" | ||
fi | fi | ||
- | echo " " | + | |
if [[ $a > $b ]] ; then | if [[ $a > $b ]] ; then | ||
echo "Les opérateurs < et > signifient avant et après selon l'ordre alphabétique (doubles crochets) " | echo "Les opérateurs < et > signifient avant et après selon l'ordre alphabétique (doubles crochets) " | ||
fi | fi | ||
- | echo " " | + | |
if [ $a \> $b ] ; then | if [ $a \> $b ] ; then | ||
echo "Les opérateurs \< et \> signifient avant et après selon l'ordre alphabétique (simples crochets) " | echo "Les opérateurs \< et \> signifient avant et après selon l'ordre alphabétique (simples crochets) " | ||
fi | fi | ||
- | </code> | + | </code><file> |
- | <code user>./mon_script</code> | + | |
- | <file config retour de la commande> | + | |
OK L'opérateur < fonctionne avec les chaînes de caractère | OK L'opérateur < fonctionne avec les chaînes de caractère | ||
Les opérateurs < et > signifient avant et après selon l'ordre alphabétique (doubles crochets) | Les opérateurs < et > signifient avant et après selon l'ordre alphabétique (doubles crochets) | ||
Ligne 509: | Ligne 312: | ||
</file> | </file> | ||
- | Avec les commandes **[** ou **test**, les opérateur **<** et **>** doivent être protégés.\\ | + | <note> |
+ | Avec les commandes **[** ou **test**, les primitives **<** et **>** doivent être protégées.\\ | ||
(Voir [[https://debian-facile.org/atelier:chantier:bash-comparaison-lexicographique-des-chaines#tests-avec1|Comparaison lexicographique avec [ ou test.]]) | (Voir [[https://debian-facile.org/atelier:chantier:bash-comparaison-lexicographique-des-chaines#tests-avec1|Comparaison lexicographique avec [ ou test.]]) | ||
+ | </note> | ||
+ | ==== Mauvais usages ==== | ||
+ | |||
+ | Les deux opérandes sont obligatoires. | ||
+ | |||
+ | <code user> | ||
+ | test GNU == ; echo $? | ||
+ | [[ != LINUX ]] | ||
+ | echo $? | ||
+ | </code><file> | ||
+ | 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> | ||
+ | |||
+ | Les espaces entre les opérandes et la primitive sont obligatoires. | ||
+ | |||
+ | <code user> | ||
+ | [ "GNU Linux"=="LINUX" ] ; echo $? | ||
+ | </code><file> | ||
+ | 0 | ||
+ | </file> | ||
+ | |||
+ | Sans espace entre les opérande et la primitive "GNU Linux"=="LINUX" est compris comme une chaîne de caractère.\\ | ||
+ | N'étant pas nulle, le test n'échoue pas. | ||