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 [30/05/2014 07:55]
Hypathie [Opérateurs lexicographiques]
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [21/02/2023 18:30]
ubub [Tester une chaîne (vide ou pas)]
Ligne 1: Ligne 1:
-======Bash : les opérateurs lexicographiques ====== 
  
-  ​* Objet : suite de la série de wiki visant à maîtriser bash via les différents caractère spéciaux.+====== Bash : Les opérateurs de test sur chaînes ====== 
 + 
 +  ​* Objet : Suite de la série de wiki visant à maîtriser bash via les caractères.
   * Niveau requis : {{tag>​débutant}}   * 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 : {{à-placer}}  +  * Suivi :  {{tag>à-tester}} 
-    * Création par **Hypathie** 08/​04/​2014 +    * Création par [[user>Hypathie]] le 08/​04/​2014 
-    * Testé par <​Hypathiele <Avril 2014 +    * Testé par [[user>Hypathie]] en Avril 2014 
-  Commentaires sur le forum : [[https://​debian-facile.org/​viewtopic.php?​pid=87499#​p87499 ​Lien vers le forum concernant ce tuto]] ((N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !)) +    Modifié par [[user|agp91]] le 21/02/2022
  
-**RAPPEL DU PLAN DE LA SÉRIE **\\ +  ​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 !)) 
  
-1) Intro I :  [[atelier:​chantier:​bash-les-differents-caracteres-speciaux|Bash : Introduction]]\\ +  * [[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]] 
 +  * [[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-iv-symboles-dans-les-calculs-mathematiques|Les symboles dans les calculs]]  
 +  * [[doc:​programmation:​shells:​page-man-bash-v-les-tableaux|Bash : les tableaux]]  
 +  * [[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]]
  
-2) chap II : [[atelier:​chantier:​la-page-man-bash-les-caracteres-speciaux|Bash : Détail et caractères]]\\ ​+===== Introduction =====
  
-3) chap III : C'est ici !\\ +<​note>​ 
 +Dans la page du manuel de bash, **les opérateurs des commandes de test** sont nommés __**primitives**__. 
 +</​note>​
  
-4) chap IV : [[atelier:​chantier:​page-man-bash-iii-les-operateurs-de-comparaison-numerique|Bash : les opérateurs ​de comparaison numérique]]\\ ​+Bash dispose de plusieurs commandes pour **réaliser des tests sur des chaînes ​de caractères**.
  
-5) chap V : [[atelier:​chantier:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques|Bash ​: les symboles dans les calculs]]\\ ​+  * 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>​
  
-6) chap VI [[atelier:​chantier:​page-man-bash-v-les-tableaux|Bash : les tableaux]]\\ ​+<​note>​ 
 +__Rappels ​:__
  
-7chap VII : [[atelier:​chantier:​man-bash-vi-les-caracteres-de-transformation-de-parametres|Bash : les caractères ​de transformation ​de parametres]]\\ ​+  *  Une commande de test renvoie le code de retour 0 (considéré comme vrailorsque le test réussi et 1 (considéré 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 a renvoyé un code de retour égal à 0. 
 +  *  L'​opérateur ​de contrôle **||** exécute la commande suivante, si la commande précédente a renvoyé un code de retour supérieur à 0. 
 +</​note>​
  
-8chap VIII : [[atelier:​chantier:​bash-vii-globs-etendus-regex|Bash : globs étendus et regex]]+===== 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.
  
-=====Opérateurs lexicographiques =====+==== Syntaxe ​====
  
-====1) Caractères de comparaison sur les chaînes de caractères ==== +  * **test OP** [**"​**]**chaîne**[**"​**] 
-  *Le shell bash utilise les opérateurs booléens sur les chaînes de caractère : == , != , >=, <= ,  +  * **[ OP** [**"​**]**chaîne**[**"​**] **]** 
-  ​*contexte : conditions (voir man bash lignes 2498-2513+  * **<nowiki>[[</​nowikiOP** [**"​**]**chaîne**[**"​**] **<nowiki>​]]</​nowiki>​**
  
-^ Condition ​           ^ Signification ​                           ^ +  ​* Avec : 
-|$chaine1 = $chaine2 ​  ​| est égal                                 | +    * **Chaîne** ​est sujette au développement des paramètres. 
-|$chaîne1 == $chaîne2 ​ | synonyme de =                            | +    * **OP**, ​l'une des primitives du tableau suivant.
-|$chaine1 != $chaine2 ​ | n'est pas égal à                         | +
-|$chaine1 < $chaîne2 ​  | avant (selon ​l'ordre alphabétique ASCII) | +
-|$chaine1 < $chaîne2 ​  | après (ASCII) ​                           |+
  
-  *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 -sont communes aux deux cas suivants ​+|  Liste des primitives de test sur chaîne ​ || 
-<​code>​ +^ Primitives ^ Retours ^ 
-Le shell bash utilise les commandes internes ​et composées ​[[ ]] ou [ ] +|''​-z''​ | Vrai si chaîne ​de longueur nulle | 
-(souvent utilisées avec IFpour les comparaisons de chaînes de caractères+|''​-n''​ | Vrai si chaîne de longueur non nulle | 
-</code>+ 
 +<​note>​ 
 +  * Si l'​opérande ​(**chaîne**) contient des espaces, il doit être protégé. 
 +  * La primitive **-n** peut-être omis. 
 +</​note>​ 
 + 
 +==== Exemples ==== 
 + 
 +<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>​ 
 +
 +
 +
 +</​file>​ 
 + 
 +<code user> 
 +test -z "​mot"​ ;​ echo $? 
 +[[ -n "​Linux"​ ]] ; echo $? 
 +[[ "GNU Linux" ]] ; echo $? 
 +</​code><​file>​ 
 +
 +
 +
 +</​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>​ 
 +
 +
 +
 +
 +</​file>​ 
 + 
 +==== Mauvais usages ==== 
 + 
 +Les directives **-z** ​et **-n** sont des directives unaires, elles n'​acceptent qu'un seul opérande (argument).\\  
 +Si sa valeur contient des espaces, cela doit être protégé par des guillemets simples ou doubles.\\ 
 +__Rappel__ ​Les guillemets simples ne permettent pas le remplacement des paramètres. 
 + 
 +<​code ​user> 
 +p="​Debian Facile"​ 
 +test -z $p ; echo $? 
 + 
 +unset p 
 +</​code><​file
 +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>​ 
 + 
 +La directive **-n** renvoie un code de retour inattendu, quand un paramètre vide est testé sans protection.\\  
 +Sauf avec la commande **<​nowiki>​[[</​nowiki>​**. 
 + 
 +<code user> 
 +test -n $p ; echo $? 
 +[ -n $p ] ; echo $? 
 + 
 +p=""​ 
 +[[ -n $p ]] ; echo $? 
 + 
 +unset p 
 +</​code><​file>​ 
 +
 +
 +
 +</​file>​ 
 + 
 +==== Astuces ==== 
 + 
 +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]]
 +<code user> 
 +p="​Debian GNU Linux"​ 
 + 
 +test -z ${p+x} ; echo $? 
 + 
 +unset p 
 +[[ -z ${p+x} ]] ; echo $? 
 +</​code><​file>​ 
 +
 +
 +</​file>​ 
 + 
 +Lors du remplacement d'un paramètre, l’opérateur **+** permet, si la valeur du paramètre est non nulle, de la substituer par une autre valeur ​(ici **x**)
 + 
 +Avec la directive **-n** ​les guillemets restent nécessaires au cas où le paramètre mémorise une chaîne vide, sauf avec la commande **<​nowiki [[</​nowiki>​**. 
 + 
 +<code user> 
 +p="​Debian Facile"​ 
 + 
 +[[ -n ${p+x} ]] ; echo $? 
 +[[ ${p+x} ]] ; echo $? 
 + 
 +unset p 
 +[[ -n ${p+x} ]] ; echo $? 
 +[[ ${p+x} ]] ; echo $? 
 +</​code><​file>​ 
 +
 +
 +
 +
 +</​file>​ 
 + 
 +===== Comparaison entre deux chaînes ​===== 
 + 
 +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>​[[</nowikichaî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** |
  
-C'est pourquoi on trouve souvent les options -z et -a du tableau ci-dessous, ajoutées au tableau ci-dessus :  +==== Exemples ====
-^ Condition ​           ^ Signification ​         ^ +
-|-z $chaine ​           | ne contient rien       | +
-|-n $chaine ​           | contient quelque-chose | +
  
-  *remarques :+<note important>​
 __-bashismes :__ __-bashismes :__
 <​code>​ <​code>​
 [[ $a == "​z*"​ ]]  # vrai si $a est égal à z* [[ $a == "​z*"​ ]]  # vrai si $a est égal à z*
 [[ $a == z* ]]    # vrai si $a commence avec un "​z"​ (reconnaissance de modèles) [[ $a == z* ]]    # vrai si $a commence avec un "​z"​ (reconnaissance de modèles)
-if [[ "​$a"​ < "​$b"​ ]]+[[ "​$a"​ < "​$b"​ ]] # vrai si $a se trouve avant $b dans le dictionnaire
 </​code>​ </​code>​
-__ +__-posix :__
--posix :__+
  
 <​code>​ <​code>​
-[ "​$a" ​== "​z*"​ ]  # vrai si $a est égal à z* +[ "​$a"​ = "​z*"​ ]  # vrai si $a est égal à z* 
-if [ "​$a"​ \< "​$b"​ ]+[ "​$a"​ \< "​$b"​ ] # vrai si $a se trouve avant $b dans le dictionnaire
 </​code>​ </​code>​
 +</​note>​
  
-<note+<code user
-Rappel:\\ +test "​GNU"​ == "​GNU"​ ] ; echo $? 
-Les opérateurs de comparaison (crochets) relève d'un mécanisme interne au shell.\\ +[[ "​GNU"​ != "GNU Linux" ]] ; echo $? 
-La commande test permet elle aussi de faire des tests.\\ ​ +</​code><​file>​ 
-Elle s'​utilise avec les mêmes expressions de comparaison mais avec cette syntaxe :\\ +
 +
 +</​file>​
  
-<code> +>Donc la chaîne "​GNU"​ est identique à elle-même ;), mais pas à "GNU Linux"​.
-test expression ​         ou bien     [ expression ]+
  
-$ test -f /​etc/​gaga ​                 $ [ -f /etc/gaga ] +<code user> 
-$ echo $?                            $ echo $? +v1="​Debian GNU Linux" 
-1                                    1 +v2="​Debian Facile"​ 
-                                   +if [ "$v1" = "$v2" ]  
-</​code>​ +then 
-Dans les deux cas, le fichier /etc/gaga n'existe pas.\\ + echo 'vrai
-(Si le fichier /etc/gaga existait, le retour serait 0.) +else 
-</​note>​+ echo '​faux'​ 
 +fi
  
-====2) Caractères de comparaison de fichiers==== +unset v1 v2 
-  *Le shell bash  +</code><​file
-<​code>​ +faux 
-Il permet d'​effectuer aussi des comparaisons sur les fichiers avec  +</file>
-les commandes internes et composées [[ ]] et [ ]] +
-(associées à IF ou non).  +
-Les commandes [[ ]] et [ ] suppléent la commande test. +
-Pour les comparaisons de nombres, on peut utiliser aussi la commande test. +
-</code>+
  
-<code> +>Donc les deux chaînes contenues dans les variables v1 et v2 ne sont pas égales.
-if [[ option $FICHIER ]] +
-</​code>​  +
- +
  
-^ test                           ^ vérifie si :                                       ^ +Copions ​le code suivant dans le fichier ​**mon_script**.
-|-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) ​ |+
  
-Exemple : +<​code ​bash mon_script>
-<​code>​+
 #!/bin/bash #!/bin/bash
-var="/​home/​hypathie/​Dossier/​fichierp1+var1="def" 
-if [ -e "$var" ] +var2="​def
-then +if [ "$var1" == "$var2" ] then 
-  echo "le fichier existe !+   ​echo "1) \$var1 ($var1) correspond(==) à \$var2 ($var2).
-else +fi 
-  echo "fichier inexistant !"+  
 +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 user>
 +a="​sloiuy"​
 +b="​aktgjaùkjayaj"​
 +
 +if [[ $a < $b ]] ; then 
 +   echo "OK l'​opérateur < fonctionne avec les chaînes de caractère"​
 fi fi
-var2="/​home/​hypathie/​Dossier/​fichierp1"​ 
-if [ -s "​$var2"​ ] 
-then 
-  echo "non vide !" 
-else 
-  echo "vide !" 
  
 +if [[ $a > $b ]] ; then 
 +   echo "Les opérateurs < et > signifient avant et après selon l'​ordre alphabétique (doubles crochets) "
 fi fi
-</​code>​+ 
 +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>​ 
 +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 la primitive sont obligatoires. 
 + 
 +<code user> 
 +[ "GNU Linux"​=="​LINUX"​ ] ; echo $? 
 +</​code><​file>​ 
 +
 +</​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.
  
  
-===Tuto précédent ===+=====Tuto précédent ​=====
  
-[[atelier:​chantier:​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 =====
  
-[[atelier:​chantier:​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