logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

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 → ODT PDF Export

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

Les deux révisions précédentes Révision précédente
Prochaine révision
Révision précédente
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [21/02/2023 00:01]
agp91 [Opérateurs sur les paramètres]
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [30/04/2023 01:23] (Version actuelle)
arpinux lien mort : page utilisateur absente
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 9: Ligne 9:
     * 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+    * Modifié par **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 !)) 
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 :   +<​note>​ 
-  ​*Les commandes ​**[** et **test**. +Dans la page du manuel de bash, **les opérateurs ​des commandes ​de test** sont nommés __**primitives**__
-  *Et la commande composée **<​nowiki>​[[</nowiki>**.+</note>
  
-Les commandes **[** et **test** sont disponibles dans leurs versions externe : **/​usr/​bin/​[** et **/​usr/​bin/​test**.\\  +Bash dispose de plusieurs commandes pour **réaliser des tests sur des chaînes de caractères**. 
-Elles ont toutes les deux la même page de manuel (**man [** ou **man test**).\\  + 
-Les commandes internes disposent ​des opérateurs ​que n'ont pas les commandes externes.+  * 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 primitives ​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éré comme vrai) lorsque le test réussi et 1 (considéreé 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 chaînes ===== +===== Tester une chaîne (vide 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. 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 ​====
-<​code>​ +
-test OP chaîne +
-[ OP chaîne ] +
-[[ OP chaîne ]]+
  
-Chaîne est sujette au développement des paramètres. +  * **test OP** [**"​**]**chaîne**[**"​**] 
-Avec pour OP, l'un des opérateur du tableau suivant. +  * **[ OP** [**"​**]**chaîne**[**"​**] **]** 
-</code>+  * **<​nowiki>​[[</​nowiki>​ OP** [**"​**]**chaîne**[**"​**] **<​nowiki>​]]</nowiki>**
  
-Si l'opérande contient ​des espaces, il doit être protégé.+  * Avec : 
 +    * **Chaîne** est sujette au développement des paramètres. 
 +    * **OP**, ​l'une des primitives du tableau suivant.
  
-|  ​Opérateurs ​de test sur chaîne ​ || +|  ​Liste des primitives ​de test sur chaîne ​ || 
-Opérateurs ^ Retours ^+Primitives ^ 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 |
  
-L'opérateur ​**-n** peut-être omis.+<​note>​ 
 +  * Si l'opérande (**chaîne**) contient des espaces, il doit être protégé. 
 +  * La primitive ​**-n** peut-être omis. 
 +</​note>​
  
-=== Exemples ​dans un terminal ​===+==== Exemples ​====
  
 <code user> <code user>
Ligne 73: Ligne 80:
 [ -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 84: Ligne 90:
 [[ -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 102: Ligne 107:
 [ "​$v"​ ] ; echo $? [ "​$v"​ ] ; echo $?
  
-</​code>​ +</​code><​file>​
-<​file ​config Retour des commandes>+
 1 1
 0 0
Ligne 110: Ligne 114:
 </​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 directives ​**-z** et **-n** sont des directives ​unaires, ​elles n'acceptent ​qu'un seul opérande (argument).\\  
-Si sa valeur contient des espaces, il doit être protégé par des guillemets doubles.+Si sa valeur contient des espaces, il doit être protégé par des guillemets ​simple ou doubles.\\ 
 +__Rappel__ : Les guillemets simple ne permettent le remplacement des paramètres.
  
-<​code>​+<​code ​user>
 p="​Debian Facile"​ p="​Debian Facile"​
 test -z $p ; echo $? test -z $p ; echo $?
  
 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>​
 +Lorsqu'​une commande interne renvoie un **code de retour 2**, cela signifie un mauvais usage de cette commande.
 +</​note>​
  
-__Rappel :__ Lorsqu'​une commande interne renvoie un code de retour 2, cela signifie un mauvais usage de cette commande. +La directive ​**-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.\\ ​+
 Sauf avec la commande **<​nowiki>​[[</​nowiki>​**. Sauf avec la commande **<​nowiki>​[[</​nowiki>​**.
  
-<​code>​+<​code ​user>
 test -n $p ; echo $? test -n $p ; echo $?
 [ -n $p ] ; echo $? [ -n $p ] ; echo $?
Ligne 139: Ligne 144:
  
 unset p unset p
-</​code>​ +</​code><​file>​
-<​file>​+
 0 0
 0 0
Ligne 146: Ligne 150:
 </​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 la directive ​**-z**, nous pouvons nous affranchir de la protection des guillemets en utilisant ​__le remplacement des paramètres__ ​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]]) (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>​+<​code ​user>
 p="​Debian GNU Linux" p="​Debian GNU Linux"
  
Ligne 157: Ligne 161:
 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
 </​file>​ </​file>​
  
-Lors du développement (remplacementd'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).+Lors du 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>​**.+Avec la directive ​**-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>​+<​code ​user>
 p="​Debian Facile"​ p="​Debian Facile"​
  
 [[ -n ${p+x} ]] ; echo $? [[ -n ${p+x} ]] ; echo $?
-[[ -${p+x} ]] ; echo $?+[[ ${p+x} ]] ; echo $?
  
 unset p unset p
 [[ -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 184: Ligne 186:
 </​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 videou 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 | +|  ​Listes des primitives ​de comparaison ​entre deux chaînes ​ || 
-| ''>''​ | Vrai si chaine2 ​est placée lexicographiquement après chaine2 |+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 ​dans un terminal ​===+==== Exemples ​====
  
 <note important>​ <note important>​
Ligne 217: Ligne 222:
 [[ "​$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 229: Ligne 233:
 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 248: Ligne 251:
  
 unset v1 v2 unset v1 v2
-</​code>​ +</​code><​file>​
-<​file ​config retour de la commande>+
 faux faux
 </​file>​ </​file>​
Ligne 255: Ligne 257:
 >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 +
-+
-bash: opérateur binaire conditionnel attendu +
-bash: erreur de syntaxe près de « LINUX » +
-+
-</​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>​ +
-+
-</​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 302: Ligne 272:
    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 319: Ligne 286:
  
 <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 ​user>
-#!/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 345: Ligne 310:
 </​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+bash: test: GNU : opérateur unaire attendu 
-fichier non trouvé ! Car il n'y a pas de développement du ~ entre guillemets (simples ou doubles). +2 
-le fichier existe ! (Sans guillemets, le développement du ~ c'est réalisé). +bash: opérateur binaire conditionnel attendu 
-le fichier existe ! +bash: erreur de syntaxe près de « LINUX » 
-le fichier existe ! +2
-'/​home/​hypathie/​toto'​ supprimé+
 </​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 =====
  
-[[doc:programmation:shells:la-page-man-bash-les-caracteres-speciaux|Bash : Détail et caractères]]+[[atelier:chantier:bash:les-operateurs-sur-parametres|Bash : Les opérateurs de test sur paramètres]]
  
 =====La suite c'est ici ===== =====La suite c'est ici =====
  
-[[doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique|Bash : les opérateurs de comparaison numérique]]+[[atelier:chantier:bash:​les-operateurs-de-test-sur-fichiers|Les opérateurs de test sur fichiers]]
doc/programmation/shells/la-page-man-bash-ii-les-operateurs-lexicographiques.1676934074.txt.gz · Dernière modification: 21/02/2023 00:01 par agp91

Pied de page des forums

Propulsé par FluxBB