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:02] agp91 [Tests sur les fichiers] |
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] |
||
---|---|---|---|
Ligne 3: | Ligne 3: | ||
* Objet : Suite de la série de wiki visant à maîtriser bash via les caractères. | * 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}} |
* Commentaires : Bash, ligne de commande et scripts | * 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à !.]] :-) | ||
Ligne 26: | Ligne 26: | ||
===== Introduction ===== | ===== Introduction ===== | ||
- | 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**. | ||
- | *Et la commande composée **<nowiki>[[</nowiki>**. | ||
- | Les commandes **[** et **test** sont disponibles dans leurs versions externe : **/usr/bin/[** et **/usr/bin/test**.\\ | + | <note> |
- | Elles ont toutes les deux la même page de manuel (**man [** ou **man test**).\\ | + | Dans la page du manuel de bash, **les opérateurs des commandes de test** sont nommées __**primitives**__. |
- | Les commandes internes disposent des opérateurs que n'ont pas les commandes externes. | + | </note> |
+ | Bash dispose de plusieurs commandes pour **réaliser des tests sur des chaînes de carractères**. | ||
+ | |||
+ | * Les commandes internes **[** et **test**. | ||
+ | * Et la commande composée **<nowiki>[[</nowiki>**. | ||
+ | <note> | ||
+ | * Les commandes **[** et **test** sont équivalentes. | ||
+ | * Les commandes **[** et **test** sont disponibles dans leurs versions externe : **/usr/bin/[** et **/usr/bin/test**. | ||
+ | * Elles ont toutes les deux la même page de manuel (**man [** ou **man test**). | ||
+ | * Les commandes internes disposent de primitive que n'ont pas les commandes externes. | ||
+ | </note> | ||
+ | |||
+ | <note> | ||
__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. | ||
- | * 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. | ||
+ | * 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 de contrôle **&&** exécute la commande suivante, si la commande précédente à renvoyée un code de retour égale à 0. | ||
+ | * L'opérateur de contrôle **||** exécute la commande suivante, si la commande précédente à renvoyée un code de retour supérieur à 0. | ||
+ | </note> | ||
+ | |||
+ | Les commandes de test disposent de 5 primitives binaires pour comparer deux chaînes entre elles. | ||
+ | |||
+ | ==== Syntaxe ==== | ||
+ | |||
+ | * **test chaîne1 OP chaîne2** | ||
+ | * **[ chaîne1 OP chaîne2 ]** | ||
+ | * **<nowiki>[[</nowiki> chaîne1 OP chaîne2 <nowiki>]]</nowiki>** | ||
+ | |||
+ | * Avec : | ||
+ | * **Chaîne1** et **chaîne2** sont sujettes au développement des paramètres. | ||
+ | * **OP**, l'un des opérateur du tableau suivant. | ||
+ | |||
+ | <note> | ||
+ | Si un opérande (**chaîne1** ou **chaîne**2) est une chaîne vide, ou contient des espaces,\\ | ||
+ | Il doit être protégé, placé entre guillemets simples ou doubles. | ||
+ | </note> | ||
+ | |||
+ | | 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> | ||
+ | __-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 ===== | ===== Opérateurs sur les chaînes ===== |