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 [15/02/2023 23:15]
ubub [Tests sur les fichiers]
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [16/02/2023 22:33]
agp91 [Comparaison de chaînes]
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
-    * MAJ par [[user>​agp91]] 15/02/2023 
  
   * 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 20: 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 =====
 +
 +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 chaîne(s) =====
 +
 +==== Test sur 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.
 +
 +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>​
 +0
 +1
 +0
 +</​file>​
 +
 +<code user>
 +test -z "​mot"​ ;​ echo $?
 +[ -n "​Linux"​ ] ; echo $?
 +[[ -z "GNU Linux" ]] ; echo $?
 +</​code>​
 +<file config Retour des commandes>​
 +1
 +0
 +1
 +</​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>​
 +1
 +0
 +0
 +</​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
 +2
 +</​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 inattendu, quand un paramètre vide est testé sans protection.
 +<​code>​
 +test -n $p ; echo $?
 +[ -n $p ] ; echo $?
 +
 +p=""​
 +[[ -n $p ]] ; echo $?
 +
 +unset p
 +</​code>​
 +<​file>​
 +0
 +0
 +1
 +</​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 $?
  
-===== Caractères ​de comparaison sur les chaînes de caractères ​====+unset p 
-  * Le shell bash utilise les opérateurs booléens sur les chaînes ​de caractère : ''​=='',​ ''​!=''​ , ''<''​ , ''>''​ et ''​=''​ ,  +</​code>​ 
-  * contexte : conditions voir man bash+<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 ====
  
-^ Condition ​           ^ Signification ​                           ^ +Les commandes ​de test disposent d'opérateurs binaires pour comparer deux chaînes entre elles.
-|$chaine1 ''​= ''​$chaine2 ​  | correspond à                             | +
-|$chaîne1 ''​==''​ $chaîne2 ​ | synonyme ​de =                            | +
-|$chaine1 ''​!=''​ $chaine2 ​ | ne correspond pas                        | +
-|$chaine1 ''<''​ $chaîne2 ​  | vrai si chaine1 est placée lexicographiquement avant chaine2 | +
-|$chaine1 ''>'​' ​$chaîne2 ​  | vrai si chaine2 est placée lexicographiquement après chaine2 |+
  
 +Syntaxe :
 +<​code>​
 +test chaîne1 OP chaîne2
 +[ chaîne1 OP chaîne2 ]
 +[[ chaîne1 OP chaîne2 ]]
  
-> 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.+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.
  
-C'est pourquoi on trouve souvent ​les options ​''​-z'' ​et ''​-n'' ​du tableau ci-dessous, ajoutées au tableau ci-dessus :  +|  Opérateurs de comparaison sur les chaînes ​ || 
-^ Condition ​           ^ Signification ​         ^ +^ Opérateurs ^ Significations ^ 
-|''​-z'' ​$chaine ​           ​ne contient rien       +''​'' ​ | Correspond à | 
-|''​-n'' ​$chaine ​           ​contient quelque-chose ​+''​=='' ​ | 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>​
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