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
Prochaine révision Les deux révisions suivantes
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [07/10/2015 19:29]
milou [Bash : les opérateurs lexicographiques]
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [16/02/2023 22:32]
agp91 [Introduction]
Ligne 1: Ligne 1:
 +
 ======Bash : les opérateurs lexicographiques ====== ======Bash : les opérateurs lexicographiques ======
  
Ligne 7: Ligne 8:
     * 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
 +
   * 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 !)) 
  
   * [[doc:​programmation:​shells:​bash-les-differents-caracteres-speciaux|Vision d'​ensemble]]   * [[doc:​programmation:​shells:​bash-les-differents-caracteres-speciaux|Vision d'​ensemble]]
-  * [[docs:​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]]
   * ;-)   * ;-)
   * [[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]]
Ligne 18: Ligne 20:
   * [[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 =====
  
-===== Caractères ​de comparaison ​sur les chaînes de caractères ​===== +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 :  ​ 
-  * Le shell bash utilise les opérateurs booléens sur les chaînes de caractère : ''​=='',​ ''​!=''​ , ''​<''​ , ''​>''​ , ''>​='',​ ''​<=''​ ,  +  *Les commandes **[** et **test**. 
-  ​contexte : conditions (voir man bash lignes 2498-2513+  *Et la commande composée **<nowiki>[[</nowiki>**.
  
-^ Condition ​           ^ Signification ​                           ^ +Les commandes **[** et **test** sont disponibles dans leurs versions externe : **/​usr/​bin/​[** et **/​usr/​bin/​test**.\\ ​ 
-|$chaine1 ''​= ''​$chaine2 ​  | correspond à                             | +Elles ont toutes les deux la même page de manuel ​(**man [** ou **man test**).\\  
-|$chaîne1 ''​==''​ $chaîne2 ​ | synonyme ​de =                            | +Les commandes internes disposent des opérateurs que n'ont pas les commandes externes.
-|$chaine1 ''​!=''​ $chaine2 ​ | ne correspond pas                        | +
-|$chaine1 ''<''​ $chaîne2 ​  | avant (selon l'​ordre alphabétique ASCII| +
-|$chaine1 ​''>''​ $chaîne2 ​  | après (ASCII) ​                           | +
-|$chaine ''>​=''​ $chaine ​   | pareil ou après ​                         | +
-|$chaine ''<​nowiki>​ <= </​nowiki>''​$chaine | pareil ou avant           |+
  
-  ​*Pour effectuer des comparaisons sur les chaînes ​de caractère((Voir Man bash ligne 2410 et man test ligne 39)) : les options -z et -a sont communes aux deux cas suivants :+__Rappels :__ 
 +  ​Une commande ​de test renvoie le code de retour **0** (considérer comme vrailorsque 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.
  
-> Le shell bash utilise les commandes internes et composées ''<​nowiki>​[[ ]]</​nowiki>''​ ou ''​[ ]''​ (souvent utilisées avec ''​if''​) pour les comparaisons de chaînes de caractères. 
  
 +===== Opérateurs sur chaîne(s) =====
  
-C'est pourquoi on trouve souvent les options ​''​-z''​ et ''​-a'' ​du tableau ci-dessousajoutées au tableau ci-dessus ​:  +==== Test sur chaîne (vide ou pas) ==== 
-Condition ​           ​Signification ​         ​+ 
-|''​-z'' ​$chaine ​           ​ne contient rien       +Les commandes de test disposent de deux opérateurs unaires pour tester si une chaîne ​est vide (de longueur nulle) ou pas. 
-|''​-n'' ​$chaine ​           ​contient quelque-chose ​+ 
 +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 ^ Signification ^ 
 +|''​-z''​ | Chaîne de longueur nulle | 
 +|''​-n''​ | Chaîne de longueur non nulle |  
 + 
 +<code user> 
 +test -z ; echo $? #Test si vide et affiche le code retour 
 +[ -n ""​ ] ; echo $? #Test si non vide et affiche le code retour 
 +[[ -z ""​ ]] ; echo $? #Test si vide et affiche le code retour 
 +</​code>​ 
 +<file config Retour des commandes>​ 
 +
 +
 +
 +</​file>​ 
 + 
 +<code user> 
 +test -z "​mot"​ ;​ echo $? 
 +[ -n "​Linux"​ ] ; echo $? 
 +[[ -z "GNU Linux" ]] ; echo $? 
 +</​code>​ 
 +<file config Retour des commandes>​ 
 +
 +
 +
 +</​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 $? 
 + 
 +</​code>​ 
 +<file config Retour des commandes>​ 
 +
 +
 +
 +</​file>​ 
 + 
 +==== Mauvais usages ==== 
 + 
 +Les opérateurs **-z** et **-n** sont des opérateurs unaires, il n'accepte qu'un seul opérande (argument).\\  
 +Ne pas protéger par des guillemets doubles, un paramètre testé, provoque une erreur, si sa valeur contient des espaces. 
 +<​code>​ 
 +p="​Debian Facile"​ 
 +test -z $p ; echo $? 
 + 
 +unset p 
 +</​code>​ 
 +<file config Retour des commandes>​ 
 +bash: test: Debian : opérateur binaire attendu 
 +
 +</​file>​ 
 + 
 +<​note>​ 
 +Lorsqu'une commande interne renvoie un code de retour 2, cela signifie un mauvais usage de cette commande. 
 +</​note>​ 
 + 
 +Avec la commande **[** ou **test**, l'opérateur **-n** revoie un code de retour inattenduquand un paramètre vide est testé sans protection. 
 +<​code>​ 
 +test -n $p ; echo $? 
 +[ -n $p ] ; echo $? 
 + 
 +p=""​ 
 +[[ -n $p ]] ; echo $? 
 + 
 +unset p 
 +</​code>​ 
 +<​file>​ 
 +
 +
 +
 +</​file>​ 
 + 
 +==== Bon usage ==== 
 + 
 +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 $? 
 +[ -z ${p+x} ] ; echo $? 
 +[[ -z ${p+x} ]] ; echo $? 
 + 
 +unset p 
 +</​code>​ 
 +<file config Retour de la commande>​ 
 +
 +
 +
 +</​file>​ 
 +Lors du développement (remplacement) d'un paramètre, l’opérateur **+** permet si la valeur du paramètre est non nul 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. 
 +===== 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 |
  
 <note important>​ <note important>​
Ligne 93: Ligne 228:
 Tests avec les crochets : Tests avec les crochets :
  
-<code bash>+<code bash mon-script>
 #!/bin/bash #!/bin/bash
 var1="​def"​ var1="​def"​
Ligne 112: Ligne 247:
 </​code>​ </​code>​
  
-> 1) test de correspondance chaîne de caractères sur valeur de variable: ​def:def correspond(==) à $var2:​def. +<file config retour de la commande> 
-2) test de correspondance chaîne de caractères sur valeur de variable: ​hip:hip correspond(=) à $var4:hip.+1) test de correspondance chaîne de caractères sur valeur de variable: ​$var1:def correspond(==) à $var2:​def. 
 +2) test de correspondance chaîne de caractères sur valeur de variable: ​$var3:hip correspond(=) à $var4:hip. 
 +</​file>​
  
 Tests avec la commande test : Tests avec la commande test :
Ligne 137: Ligne 274:
 </​note>​ </​note>​
  
-<code bash>+<code bash script>
 #!/bin/bash #!/bin/bash
 a="​sloiuy"​ a="​sloiuy"​
 b="​aktgjaùkjayaj"​ b="​aktgjaùkjayaj"​
 if [[ $a < $b ]] ; then  if [[ $a < $b ]] ; then 
-   echo " "+   echo "OK l'​opérateur < fonctionne avec les chaînes de caractère"
 fi fi
-echo "OK l'​opérateur < fonctionne avec les chaînes de caractère"+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 " " 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> ​
- +<code user>​./​mon_script</​code>​ 
-> L'​opérateur ​''​<'' ​fonctionne avec les chaînes de caractère. +<file config retour de la commande> 
-+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) 
-+Les opérateurs ​\< et \> signifient avant et après selon l'​ordre alphabétique (simples crochets) ​ 
-Les opérateurs ​''​<'' ​et ''​>'' ​signifient avant et après selon l'​ordre alphabétique (simples crochets) ​+</​file>​
  
  
 ===== Tests sur les fichiers===== ===== Tests sur les fichiers=====
  
-  *Le shell bash  +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).).
- +
-> Il permet d'​effectuer aussi des comparaisons ​sur les fichiers avec les commandes internes et composées ​''<​nowiki>​[[ ]]</​nowiki>''​ et ''<​nowiki>​[ ]</​nowiki>''​ (associées à IF ou non). +
->  +
-> Les commandes ''<​nowiki>​[[ ]]</​nowiki>''​ et ''<​nowiki>​[ ]</​nowiki>''​ suppléent la commande test.+
  
 <code bash> <code bash>
Ligne 173: Ligne 306:
 </​code> ​ </​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.|
  
-^ options de test                ^ vérifie si                                      ^ +Remarque ​L'opérateur **-e** teste si le fichier existe ​quelque soit son statut (fichierrépertoirelien, etc).
-|''-e''​ $nomfichier ​             | le fichier existe ​                                |  +
-|''​-d''​ $nomfichier ​             | le fichier ​est un répertoire ​                     | +
-|''​-f''​ $nomfichier ​             | le fichier est un document ​                       | +
-|''​-L''​ $nomfichier ​             | le fichier est un lien symbolique ​                |  +
-|''​-r''​ $nomfichier ​             | le fichier est lisible ​                           | +
-|''​-w''​ $nomfichier ​             | le fichier est modifiable ​                        | +
-|''​-x''​ $nomfichier ​             | le fichier est exécutable ​                        | +
-|$fichier1 ''​-nt''​ $fichier2 ​    | fichier1 est plus récent que fichier2 (newerthan) | +
-|$fichier1 ''​-ot''​ $fichier2 ​    | fichier1 est plus vieux que fichier2 (olderthan |+
  
-  * Avec commande test ou crochets : +==== Test dans un script ====  
-(Soit le fichier ordinaire "​toto"​ dans le répertoire courant de l'​utilisateur) +Soit le script mon_script. 
-<code bash>+<code bash script>
 #!/bin/bash #!/bin/bash
 var1="​~/​toto"​ var1="​~/​toto"​
Ligne 194: Ligne 344:
   echo "le fichier existe !"   echo "le fichier existe !"
 else else
-  echo "​fichier ​inexistant: ​le fichier existe ​mais dans un script il faut le chemin absolu ​du fichier ​testé ​!"+  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 fi
  
Ligne 204: Ligne 362:
   echo "​fichier inexistant !"   echo "​fichier inexistant !"
 fi fi
-echo " " + 
-var2="​home/​hypathie/​toto"​ +if test -f "$var1"
-if test -f "$var2"+
 then then
   echo "le fichier existe !"   echo "le fichier existe !"
Ligne 213: Ligne 370:
 fi fi
 </​code>​ </​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>​
  
-  * Les tests sur les fichiers ​dans le terminal ​avec commande test +==== Tests en ligne de commande ==== 
-(Soit le fichier ordinaire "​toto"​)+Tests dans un terminal ​des commande ​**test** et **[**.
  
 <code user> <code user>
 +touch ~/toto
 +
 test -f /​home/​hypathie/​toto test -f /​home/​hypathie/​toto
-#puis 
 echo $? echo $?
-</​code>​ +
-<file config retour de la commande>​ +
-  0 +
-</​file>​ +
-  * Les tests sur les fichiers dans le terminal avec les crochets : +
-<code user>+
 [ -f ~/toto ] [ -f ~/toto ]
-#puis 
 echo $? echo $?
-</​code>​  + 
-<​file ​config ​retour de la commande>​ +rm -v ~/toto 
-  0+</​code>​ 
 +<file retour de la commande>​ 
 +0 
 +
 +'/​home/​hypathie/​toto'​ supprimé
 </​file>​ </​file>​
 +
 Et voilà ! 8-) Et voilà ! 8-)
  
-====Tuto précédent ====+=====Tuto précédent ​=====
  
-[[docs:​programmation:​shells:​la-page-man-bash-les-caracteres-speciaux|Bash : Détail et caractères]]+[[doc:​programmation:​shells:​la-page-man-bash-les-caracteres-speciaux|Bash : Détail et caractères]]
  
-====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]] [[doc:​programmation:​shells:​page-man-bash-iii-les-operateurs-de-comparaison-numerique|Bash : les opérateurs de comparaison numérique]]
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