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:00] agp91 [Bash : les opérateurs lexicographiques] |
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [21/02/2023 00:26] agp91 [Opérateurs sur les 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> | ||
- | ===== Opérateurs sur les paramètres ===== | + | Les commandes de test disposent de 5 primitives binaires pour comparer deux chaînes entre elles. |
- | Les commandes de test disposent de deux opérateurs unaires pour tester les paramètres. | + | ==== Syntaxe ==== |
- | <code> | + | * **test chaîne1 OP chaîne2** |
- | test OP nom_paramètre | + | * **[ chaîne1 OP chaîne2 ]** |
- | [ OP nom_paramètre ] | + | * **<nowiki>[[</nowiki> chaîne1 OP chaîne2 <nowiki>]]</nowiki>** |
- | [[ OP nom_paramètre ]] | + | |
- | Chaîne est sujette au développement des paramètres. | + | * Avec : |
- | Avec pour OP, l'un des opérateur du tableau suivant. | + | * **Chaîne1** et **chaîne2** sont sujettes au développement des paramètres. |
- | </code> | + | * **OP**, l'un des opérateur du tableau suivant. |
- | | Opérateurs sur paramètre || | + | <note> |
- | ^ Opérateurs ^ Retours ^ | + | Si un opérande (**chaîne1** ou **chaîne**2) est une chaîne vide, ou contient des espaces,\\ |
- | |''-v'' | Vrai si le paramètre existe | | + | Il doit être protégé, placé entre guillemets simples ou doubles. |
- | |''-R'' | Vrai si le paramètre est une référence de nom | | + | </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 ==== | ==== Exemples ==== | ||
- | |||
- | Testons si le paramètre var existe. | ||
- | |||
- | <code user> | ||
- | var="Debian Facile" # var existe et n'est pas une chaîne vide | ||
- | [ -v var ] ; echo $? | ||
- | |||
- | var= # var existe et est une chaîne vide | ||
- | test -v var ; echo $? | ||
- | |||
- | unset var # Destruction de var (var n’existe plus). | ||
- | [[ -v var ]] ; echo $? | ||
- | </code> | ||
- | <file> | ||
- | 0 | ||
- | 0 | ||
- | 1 | ||
- | </file> | ||
- | |||
- | __Rappel :__ Une référence de nom est un paramètre qui mémorise le nom d'un autre paramètre.\\ | ||
- | Il est nécessaire d'utilisé la commande **declare -n** pour construire une référence de nom. | ||
- | |||
- | <code> | ||
- | var="Debian GNU Linux" | ||
- | declare -n v=var | ||
- | |||
- | echo var=$var | ||
- | echo v=$v | ||
- | v="Debian Facile" | ||
- | echo var=$var | ||
- | |||
- | [ -R var ] ; echo $? | ||
- | [[ -R v ]] ; echo $? | ||
- | |||
- | declare -p var v | ||
- | |||
- | unset var v | ||
- | </code> | ||
- | <file config Retour des commandes> | ||
- | var=Debian GNU Linux | ||
- | v=Debian GNU Linux | ||
- | var=Debian Facile | ||
- | 1 | ||
- | 0 | ||
- | declare -- var="Debian Facile" | ||
- | declare -n v="var" | ||
- | </file> | ||
- | |||
- | ===== 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 | | ||
- | |''-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 284: | Ligne 85: | ||
[[ "$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 296: | Ligne 96: | ||
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 315: | Ligne 114: | ||
unset v1 v2 | unset v1 v2 | ||
- | </code> | + | </code><file> |
- | <file config retour de la commande> | + | |
faux | faux | ||
</file> | </file> | ||
Ligne 322: | Ligne 120: | ||
>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 369: | Ligne 135: | ||
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 386: | Ligne 149: | ||
<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 412: | Ligne 173: | ||
</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> | ||
- | ===== Opérateurs numériques ===== | + | ==== Mauvais usages ==== |
- | Les commandes de tests disposent d'opérateurs permettant de réaliser des comparaison numérique.\\ | + | Les deux opérandes sont obligatoires. |
- | Voir [[https://debian-facile.org/doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique#comparaison-numerique-avec-et|Comparaison numérique avec [ (ou test) et [[]] | + | |
- | ===== Tests sur les fichiers===== | + | |
- | Le shell bash permet d'effectuer aussi des tests sur les fichiers avec la commande interne composée ''<nowiki>[[ ]]</nowiki>'' et la commande interne ''<nowiki>[ ]</nowiki>'' (associées à if ou non).). | ||
- | |||
- | <code bash> | ||
- | if [[ option $FICHIER ]] | ||
- | </code> | ||
- | |||
- | |Extrait de la page du manuel de bash section CONDITIONS|| | ||
- | ^ Opérateurs ^ Retours : ^ | ||
- | |-a fichier |Vrai si le fichier existe.| | ||
- | |-b fichier |Vrai si le fichier existe et est un fichier spécial bloc.| | ||
- | |-c fichier |Vrai si le fichier existe et est un fichier spécial caractère.| | ||
- | |-d fichier |Vrai si le fichier existe et est un répertoire.| | ||
- | |-e fichier |Vrai si le fichier existe.| | ||
- | |-f fichier |Vrai si le fichier existe et est un fichier normal.| | ||
- | |-g fichier |Vrai si le fichier existe et a son bit Set-GID positionné.| | ||
- | |-h fichier |Vrai si le fichier existe et est un lien symbolique.| | ||
- | |-k fichier |Vrai si le fichier existe et a son bit « sticky » positionné.| | ||
- | |-p fichier |Vrai si le fichier existe et est un tube nommé (FIFO).| | ||
- | |-r fichier |Vrai si le fichier existe et est accessible en lecture.| | ||
- | |-s fichier |Vrai si le fichier existe et a une taille strictement positive.| | ||
- | |-t df |Vrai si le descripteur de fichier df est ouvert et se rapporte à un terminal.| | ||
- | |-u fichier |Vrai si le fichier existe et a son bit Set-UID positionné.| | ||
- | |-w fichier |Vrai si le fichier existe et est accessible en écriture.| | ||
- | |-x fichier |Vrai si le fichier existe et est exécutable.| | ||
- | |-G fichier |Vrai si le fichier existe et appartient au GID effectif du groupe.| | ||
- | |-L fichier |Vrai si le fichier existe et est un lien symbolique.| | ||
- | |-N fichier |Vrai si le fichier existe et a été modifié depuis sa dernière lecture.| | ||
- | |-O fichier |Vrai si le fichier existe et appartient à l'UID effectif de l'utilisateur.| | ||
- | |-S fichier |Vrai si le fichier existe et est une socket.| | ||
- | |fichier_1 -ef fichier_2 |Vrai si le fichier_1 et le fichier_2 se rapportent au même périphérique et ont les mêmes numéros d'inœuds.| | ||
- | |fichier_1 -nt fichier_2 |Vrai si le fichier_1 est plus récent que le fichier_2 (selon les dates de dernière modification) ou si fichier_1 existe et non fichier_2.| | ||
- | |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** teste si le fichier existe quelque soit son statut (fichier, répertoire, lien, etc). | ||
- | |||
- | ==== Test dans un script ==== | ||
- | Soit le script mon_script. | ||
- | <code bash script> | ||
- | #!/bin/bash | ||
- | var1="~/toto" | ||
- | if [ -f "$var1" ] | ||
- | then | ||
- | echo "le fichier existe !" | ||
- | else | ||
- | echo "fichier non trouvé ! Car il n'y a pas de développement du ~ entre guillemets (simples ou doubles)." | ||
- | fi | ||
- | |||
- | var1=~/toto # Sans guillemets, le ~ est développé. | ||
- | if [ -f "$var1" ] | ||
- | then | ||
- | echo "le fichier existe ! (Sans guillemets, le développement du ~ c'est réalisé)." | ||
- | else | ||
- | echo "fichier inexistant !" | ||
- | fi | ||
- | |||
- | var1="home/hypathie/toto" | ||
- | if [ -f "$var1" ] | ||
- | then | ||
- | echo "le fichier existe !" | ||
- | else | ||
- | echo "fichier inexistant !" | ||
- | fi | ||
- | |||
- | if test -f "$var1" | ||
- | then | ||
- | echo "le fichier existe !" | ||
- | else | ||
- | echo "fichier inexistant !" | ||
- | fi | ||
- | </code> | ||
<code user> | <code user> | ||
- | touch ~/toto | + | test GNU == ; echo $? |
- | bash mon_script | + | [[ != LINUX ]] |
- | rm -v ~/toto | + | echo $? |
- | </code> | + | </code><file> |
- | <file retour de la commande> | + | echo $? |
- | fichier non trouvé ! Car il n'y a pas de développement du ~ entre guillemets (simples ou doubles). | + | bash: test: GNU : opérateur unaire attendu |
- | le fichier existe ! (Sans guillemets, le développement du ~ c'est réalisé). | + | 2 |
- | le fichier existe ! | + | bash: opérateur binaire conditionnel attendu |
- | le fichier existe ! | + | bash: erreur de syntaxe près de « LINUX » |
- | '/home/hypathie/toto' supprimé | + | 2 |
</file> | </file> | ||
- | ==== Tests en ligne de commande ==== | + | Les espaces entre les opérandes et la primitive sont obligatoires. |
- | Tests dans un terminal des commande **test** et **[**. | + | |
<code user> | <code user> | ||
- | touch ~/toto | + | [ "GNU Linux"=="LINUX" ] ; echo $? |
- | + | </code><file> | |
- | test -f /home/hypathie/toto | + | |
- | echo $? | + | |
- | + | ||
- | [ -f ~/toto ] | + | |
- | echo $? | + | |
- | + | ||
- | rm -v ~/toto | + | |
- | </code> | + | |
- | <file retour de la commande> | + | |
- | 0 | + | |
0 | 0 | ||
- | '/home/hypathie/toto' supprimé | ||
</file> | </file> | ||
- | Et voilà ! 8-) | + | 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. | ||
=====Tuto précédent ===== | =====Tuto précédent ===== |