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
Dernière révision Les deux révisions suivantes
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [20/02/2023 13:29]
agp91 [Opérateurs sur les chaînes]
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [21/02/2023 18:38]
ubub ancienne révision (21/02/2023 02:54) restaurée
Ligne 1: Ligne 1:
  
-======Bash : les opérateurs ​lexicographiques ​======+====== Bash : Les opérateurs ​de test sur chaînes ​======
  
-  * Objet : suite de la série de wiki visant à maîtriser bash via les différents caractère spéciaux+  * 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
   * 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à !.]] :-)
-  * Suivi : +  * Suivi :  ​{{tag>​à-tester}}
     * 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
  
   * 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 13: Ligne 15:
   * [[doc:​programmation:​shells:​bash-les-differents-caracteres-speciaux|Vision d'​ensemble]]   * [[doc:​programmation:​shells:​bash-les-differents-caracteres-speciaux|Vision d'​ensemble]]
   * [[doc:​programmation:​shells:​la-page-man-bash-les-caracteres-speciaux|Détail et caractères]]   * [[doc:​programmation:​shells:​la-page-man-bash-les-caracteres-speciaux|Détail et caractères]]
-  * ;-)+  ​* [[atelier:​chantier:​bash:​les-operateurs-sur-parametres|Les opérateurs de test sur paramètres]] 
 +  * **Les opérateurs de test sur chaînes** ;-) 
 +  * [[atelier:​chantier:​bash:​les-operateurs-de-test-sur-fichiers|Les opérateurs de test sur fichiers]]
   * [[doc:​programmation:​shells:​page-man-bash-iii-les-operateurs-de-comparaison-numerique|Les opérateurs de comparaison numérique]]   * [[doc:​programmation:​shells:​page-man-bash-iii-les-operateurs-de-comparaison-numerique|Les opérateurs de comparaison numérique]]
   * [[doc:​programmation:​shells:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques|Les symboles dans les calculs]] ​   * [[doc:​programmation:​shells:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques|Les symboles dans les calculs]] ​
Ligne 19: Ligne 23:
   * [[doc:​programmation:​shells:​man-bash-vi-les-caracteres-de-transformation-de-parametres|Les caractères de transformation de parametres]]   * [[doc:​programmation:​shells:​man-bash-vi-les-caracteres-de-transformation-de-parametres|Les caractères de transformation de parametres]]
   * [[doc:​programmation:​shells:​bash-vii-globs-etendus-regex|Bash : Variables, globs étendus, ERb, ERe]]   * [[doc:​programmation:​shells:​bash-vii-globs-etendus-regex|Bash : Variables, globs étendus, ERb, ERe]]
- 
-===== 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**.\\ ​ 
-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. 
- 
-__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. 
- 
- 
-===== Opérateurs sur les paramètres ===== 
- 
-Les commandes de test disposent de deux opérateurs unaires pour tester les paramètres. 
- 
-<​code>​ 
-test OP nom_paramètre 
-[ OP nom_paramètre ] 
-[[ OP nom_paramètre ]] 
- 
-Chaîne est sujette au développement des paramètres. 
-Avec pour OP, l'un des opérateur du tableau suivant. 
-</​code>​ 
- 
-|  Opérateurs sur paramètre ​ || 
-^ Opérateurs ^ Retours ^ 
-|''​-v''​ | Vrai si le paramètre existe | 
-|''​-R''​ | Vrai si le paramètre est une référence de nom | 
- 
- 
-==== 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>​ 
- 
-====== Les opérateurs de test sur chaînes ====== 
  
 ===== Introduction ===== ===== Introduction =====
  
 <​note>​ <​note>​
-Dans la page du manuel de bash, **les opérateurs des commandes de test** sont nommées ​__**primitives**__.+Dans la page du manuel de bash, **les opérateurs des commandes de test** sont nommés ​__**primitives**__.
 </​note>​ </​note>​
  
-Bash dispose de plusieurs commandes pour réaliser des tests sur des paramètres.+Bash dispose de plusieurs commandes pour **réaliser des tests sur des chaînes de caractères**.
  
   * Les commandes internes **[** et **test**.   * Les commandes internes **[** et **test**.
Ligne 121: Ligne 38:
   * Les commandes **[** et **test** sont disponibles dans leurs versions externe : **/​usr/​bin/​[** et **/​usr/​bin/​test**.   * 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**).     * 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.+  * Les commandes internes disposent de primitives ​que n'ont pas les commandes externes.
 </​note>​ </​note>​
  
Ligne 127: Ligne 44:
 __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é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 $?.   *  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 é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.   *  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>​ </​note>​
- 
-Les commandes de test disposes de 7 primitives (2 unaires et 5 binaires) pour tester des chaînes. ​ 
- 
  
 ===== Tester une chaîne (vide ou pas) ===== ===== Tester une chaîne (vide ou pas) =====
Ligne 140: Ligne 54:
 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.
  
-==== Synopsis ​====+==== Syntaxe ​====
  
-  * **test OP chaîne** +  * **test OP** [**"​**]**chaîne**[**"​**] 
-  * **[ OP chaîne ]** +  * **[ OP** [**"​**]**chaîne**[**"​**] **]** 
-  * **<​nowiki>​[[</​nowiki>​ OP chaîne <​nowiki>​]]</​nowiki>​**+  * **<​nowiki>​[[</​nowiki>​ OP** [**"​**]**chaîne**[**"​**] **<​nowiki>​]]</​nowiki>​**
  
   * Avec :   * Avec :
     * **Chaîne** est sujette 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.
  
-|  Liste des primitives de test sur une chaîne ​ || +|  Liste des primitives de test sur chaîne ​ || 
-^ Primitives ^ 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 |
  
 <​note>​ <​note>​
-La primitive **-n** peut-être omis.+  * Si l'​opérande (**chaîne**) contient des espaces, il doit être protégé. 
 +  * La primitive **-n** peut-être omis.
 </​note>​ </​note>​
  
 ==== Exemples ==== ==== Exemples ====
- 
-Testons une chaîne vide. 
  
 <code user> <code user>
Ligne 172: Ligne 85:
 1 1
 </​file>​ </​file>​
- 
-Testons une chaînes non vide. 
  
 <code user> <code user>
Ligne 179: Ligne 90:
 [[ -n "​Linux"​ ]] ; echo $? [[ -n "​Linux"​ ]] ; echo $?
 [[ "GNU Linux" ]] ; echo $? [[ "GNU Linux" ]] ; echo $?
-</​code><​code>+</​code><​file>
 1 1
 0 0
 0 0
-</code> +</file>
- +
-Testons la variable **v** si elle est, de longueur non nulle, nulle ou si elle n'​existe pas.+
  
 <code user> <code user>
Ligne 194: Ligne 103:
 [ -n "​$v"​ ] ; echo $? [ -n "​$v"​ ] ; echo $?
  
-unset v # Supprime le paramètre v (il n'​existe plus).+unset v # Supprime le paramètre v
 [[ -z "​$v"​ ]] ; echo $? [[ -z "​$v"​ ]] ; echo $?
 [ "​$v"​ ] ; echo $? [ "​$v"​ ] ; echo $?
Ligne 207: Ligne 116:
 ==== 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 user> <code user>
Ligne 219: Ligne 129:
 2 2
 </​file>​ </​file>​
- 
 <​note>​ <​note>​
-  * 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>​ </​note>​
  
-L'​opérateur ​**-n** ​renvoie ​un code de retour inattendu, quand un paramètre vide est testé sans protection.\\ ​+La directive ​**-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>​**.
  
Ligne 243: Ligne 152:
 ==== Astuces ==== ==== Astuces ====
  
-Avec la primitive ​**-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 user> <code user>
 p="​Debian GNU Linux" p="​Debian GNU Linux"
Ligne 258: Ligne 166:
 </​file>​ </​file>​
  
-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**).+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 la primitive ​**-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 user> <code user>
Ligne 266: Ligne 174:
  
 [[ -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><​file>​ </​code><​file>​
 0 0
Ligne 381: Ligne 289:
 </​note>​ </​note>​
  
-<​code ​usert>+<​code ​user>
 a="​sloiuy"​ a="​sloiuy"​
 b="​aktgjaùkjayaj"​ b="​aktgjaùkjayaj"​
Ligne 416: Ligne 324:
 echo $? echo $?
 </​code><​file>​ </​code><​file>​
-echo $? 
 bash: test: GNU : opérateur unaire attendu bash: test: GNU : opérateur unaire attendu
 2 2
Ligne 435: Ligne 342:
 N'​étant pas nulle, le test n'​échoue pas. N'​étant pas nulle, le test n'​échoue pas.
  
----- 
-|[[url-invalid|<<​ Précédant : Les opérateurs de test sur les paramètres]] |  [url-invalide|**Suivant >>** : Les opérateur de test sur les fichiers] | 
-===== Opérateurs numériques ===== 
- 
-Les commandes de tests disposent d'​opérateurs permettant de réaliser des comparaison numérique.\\ ​ 
-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> 
-touch ~/toto 
-bash mon_script 
-rm -v ~/toto 
-</​code>​ 
-<file retour de la commande>​ 
-fichier non trouvé ! Car il n'y a pas de développement du ~ entre guillemets (simples ou doubles). 
-le fichier existe ! (Sans guillemets, le développement du ~ c'est réalisé). 
-le fichier existe ! 
-le fichier existe ! 
-'/​home/​hypathie/​toto'​ supprimé 
-</​file>​ 
- 
-==== Tests en ligne de commande ==== 
-Tests dans un terminal des commande **test** et **[**. 
- 
-<code user> 
-touch ~/toto 
- 
-test -f /​home/​hypathie/​toto 
-echo $? 
- 
-[ -f ~/toto ] 
-echo $? 
- 
-rm -v ~/toto 
-</​code>​ 
-<file retour de la commande>​ 
-0 
-0 
-'/​home/​hypathie/​toto'​ supprimé 
-</​file>​ 
- 
-Et voilà ! 8-) 
  
 =====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.txt · Dernière modification: 30/04/2023 01:23 par arpinux

Pied de page des forums

Propulsé par FluxBB