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 [08/04/2014 15:49]
Hypathie [page man Bash : II, Opérateurs lexicographiques]
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [21/02/2023 02:14]
agp91 [Tuto précédent]
Ligne 1: Ligne 1:
-======page man Bash : II, Opérateurs lexicographiques ====== 
  
-  ​* Objet : ne plus confondre ​les différents ​caractères ​de BASH +====== 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 : //Contexte d'​utilisation du sujet du tuto. // FIXME+  * 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 : {{à-tester ​à-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> FIXME +    * Testé par [[user>Hypathie]] en Avril 2014 
-  Commentaires sur le forum : [[url Lien vers le forum concernant ce tuto]] ((N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !)) FIXME+    Modifié par [[user|agp91]] le 21/02/2022
  
-**Nota : suite du "petit commentaire ​sur la page man Bash** +  ​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  celui de ce fil [url=http://wiki.debian-facile.org/​atelier:​chantier:​bash-les-differents-caracteres-speciaux?&#meta-caracteres-et-meta-caracteres|méta-caractères et méta-caractères[/​url]+
  
-2) chap I : [[atelier:chantier:​la-page-man-bash-les-caracteres-speciaux|caractères ​spéciaux]]+  * [[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]]
  
-3) chap II : c'est ici ! +===== Introduction =====
  
-4) chap III : [[atelier:​chantier:​page-man-bash-iii-les-operateurs-de-comparaison-numerique|opérateurs de comparaison numérique]]+<​note>​ 
 +Dans la page du manuel de bash, **les opérateurs ​des commandes ​de test** sont nommées __**primitives**__. 
 +</​note>​
  
-5) chap IV : [[atelier:​chantier:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques|symboles dans les calculs]]+Bash dispose de plusieurs commandes pour **réaliser des tests sur des chaînes de carractères**.
  
-6) chap V : [[atelier:​chantier:page-man-bash-v-les-tableaux|les tableaux]]+  * 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>​
  
-7) chap VI [[atelier:​chantier:​man-bash-vi-les-caracteres-de-transformation-de-parametres|caractères de transformations de paramètres]]+<​note>​ 
 +__Rappels ​:__
  
-Contributeurs,​ les FIXME sont là pour vous aider, supprimez-les une fois le problème corrigé ou le champ rempli !+  *  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 lexicographiques ​=====+===== Tester une chaîne (vide ou pas) =====
  
-====1) Caractères ​de comparaison sur les chaînes ​de caractères ==== +Les commandes ​de test disposent ​de deux opérateurs ​unaires pour tester si une chaîne est vide (de longueur nulle) ou pas.
-  *Le shell bash utilise les opérateurs ​booléens sur les chaînes de caractère : == , != , < , > , >=, <= ,  +
-  *contexte : conditions ​(voir man bash lignes 2498-2513+
  
-^ Condition ​           ^ Signification ​                           ^ +==== Syntaxe ====
-|$chaine1 ​$chaine2 ​  | est égal                                 | +
-|$chaîne1 ​== $chaîne2 ​ | synonyme de                            | +
-|$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 -a sont communes aux deux cas suivants : +  * **test OP** [**"​**]**chaîne**[**"​**] 
-<code> +  * **[ OP** [**"​**]**chaîne**[**"​**] **]** 
-Le shell bash utilise les commandes internes et composées ​[[ ]] ou [ ] +  * **<nowiki>[[</​nowiki>​ OP** [**"**]**chaîne**[**"**] **<​nowiki>​]]</nowiki>**
-(souvent utilisées avec IF) pour les comparaisons de chaînes de caractères. +
-</code>+
  
-C'est pourquoi on trouve souvent les options -z et -a du tableau ​ci-dessous, ajoutées au tableau ci-dessus :  +  * Avec : 
-^ Condition ​           ^ Signification ​         ^ +    * **Chaîne** est sujette au développement des paramètres. 
-|-z $chaine ​           | ne contient rien       | +    * **OP**, l'une des primitives ​du tableau ​suivant.
-|-n $chaine ​           | contient quelque-chose | +
  
-  ​*remarques ​:+|  Liste des primitives de test sur chaîne ​ || 
 +^ Primitives ^ Retours ^ 
 +|''​-z''​ | Vrai si chaîne de longueur nulle | 
 +|''​-n''​ | Vrai si chaîne de longueur non nulle | 
 + 
 +<​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, il doit être protégé par des guillemets simple ou doubles.\\ 
 +__Rappel__ ​Les guillemets simple ne permettent 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** revoie 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 substituée par une autre valeur (ici **x**). 
 + 
 +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> 
 +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>​[[</​nowiki>​ chaî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** | 
 + 
 +==== Exemples ==== 
 + 
 +<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>​
  
 +<code user>
 +test "​GNU"​ == "​GNU"​ ] ; echo $?
 +[[ "​GNU"​ != "GNU Linux" ]] ; echo $?
 +</​code><​file>​
 +0
 +0
 +</​file>​
  
-====2) Caractères de comparaison de fichiers==== +>Donc la chaîne "​GNU"​ est identique ​à elle-même ;), mais pas à "GNU Linux".
-  *Le shell bash  +
-<code> +
-Il permet d'​effectuer aussi des comparaisons sur les fichiers avec  +
-les commandes internes et composées [[ ]] et [ ]] +
-(associées ​à IF ou non).  +
-Les commandes [[ ]] et [ ] suppléent la commande test. +
-Pour les comparaisons de nombreson peut utiliser aussi la commande test. +
-</​code>​+
  
-<​code>​ +<​code ​user> 
-if [[ option ​$FICHIER ]+v1="​Debian GNU Linux"​ 
-</​code> ​ +v2="​Debian Facile"​ 
- +if [ "$v1" = "​$v2" ​]  
 +then 
 + echo '​vrai'​ 
 +else 
 + echo '​faux'​ 
 +fi
  
-^ test                           ^ vérifie si :                                       ^ +unset v1 v2 
-|-e $nomfichier ​                 | le fichier existe ​                                ​| ​ +</​code><​file>​ 
-|-d $nomfichier ​                 | le fichier est un répertoire ​                     | +faux 
-|-f $nomfichier ​                 | le fichier est un document ​                       | +</​file>​
-|-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 : +>Donc les deux chaînes contenues dans les variables v1 et v2 ne sont pas égales. 
-<​code>​+ 
 +Copions le code suivant dans le fichier **mon_script**. 
 + 
 +<​code ​bash mon_script>
 #!/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>​
 +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 la primitive sont obligatoires.
 +
 +<code user>
 +[ "GNU Linux"​=="​LINUX"​ ] ; echo $?
 +</​code><​file>​
 +0
 +</​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 =====
  
-===La suite c'est ici : === +[[atelier:​chantier:​bash:les-operateurs-sur-parametres|Bash : Les opérateurs ​de test sur paramètres]]
-[[atelier:​chantier:​page-man-bash-iii-les-operateurs-de-comparaison-numerique]]+
  
-===Tuto précédent ​=== +=====La suite c'est ici =====
-[[atelier:​chantier:​la-page-man-bash-les-caracteres-speciaux?&#​les-caracteres-speciaux]]+
  
 +[[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