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 [16/02/2023 22:42]
agp91 [Opérateurs sur chaîne(s)]
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [20/02/2023 13:29]
agp91 [Opérateurs sur les chaînes]
Ligne 37: Ligne 37:
  
  
-===== Opérateurs sur chaîne(s) ​=====+===== Opérateurs sur les paramètres ​=====
  
-==== Tester une chaîne (vide ou pas) ====+Les commandes de test disposent de deux opérateurs unaires pour tester les paramètres.
  
-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>​ <​code>​
-test OP chaîne +test OP nom_paramètre 
-[ OP chaîne ​+[ OP nom_paramètre ​
-[[ OP chaîne ​]]+[[ OP nom_paramètre ​]]
  
 Chaîne est sujette au développement des paramètres. Chaîne est sujette au développement des paramètres.
Ligne 53: Ligne 50:
 </​code>​ </​code>​
  
-Si l'​opérande contient des espaces, il doit être protégé +|  Opérateurs sur paramètre ​ || 
-|  Opérateurs ​de test sur chaîne ​ || +^ Opérateurs ^ ​Retours
-^ Opérateurs ^ ​Signification +|''​-v''​ | ​Vrai si le paramètre existe
-|''​-z''​ | ​Chaîne de longueur nulle +|''​-R''​ | ​Vrai si le paramètre est une référence ​de nom |
-|''​-n''​ | ​Chaîne ​de longueur non nulle +
  
-=== Exemples ===+ 
 +==== Exemples ===
 + 
 +Testons si le paramètre var existe.
  
 <code user> <code user>
-test -z ; echo $? #Test si vide et affiche le code retour +var="​Debian Facile"​ # var existe et n'est pas une chaîne vide 
--n ""​ ] ; echo $? #Test si non vide et affiche le code retour +[ -v var ] ; echo $? 
-[[ -z "" ​]] ; echo $? #Test si vide et affiche le code retour+ 
 +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>​ </​code>​
-<​file ​config Retour des commandes>+<​file>​ 
 +0
 0 0
 1 1
-0 
 </​file>​ </​file>​
  
-<​code ​user+__Rappel :__ Une référence de nom est un paramètre qui mémorise le nom d'un autre paramètre.\\  
-test -"mot" echo $? +Il est nécessaire d'​utilisé la commande **declare -n** pour construire une référence de nom. 
-[ -n "​Linux" ​] ; echo $? + 
-[[ -z "GNU Linux" ​]] ; echo $?+<​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>​ </​code>​
 <file config Retour des commandes>​ <file config Retour des commandes>​
 +var=Debian GNU Linux
 +v=Debian GNU Linux
 +var=Debian Facile
 1 1
 0 0
 +declare -- var="​Debian Facile"​
 +declare -n v="​var"​
 +</​file>​
 +
 +====== Les opérateurs de test sur chaînes ======
 +
 +===== Introduction =====
 +
 +<​note>​
 +Dans la page du manuel de bash, **les opérateurs des commandes de test** sont nommées __**primitives**__.
 +</​note>​
 +
 +Bash dispose de plusieurs commandes pour réaliser des tests sur des paramètres.
 +
 +  * 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>​
 +
 +<​note>​
 +__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 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>​
 +
 +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) =====
 +
 +Les commandes de test disposent de deux opérateurs unaires pour tester si une chaîne est vide (de longueur nulle) ou pas.
 +
 +==== Synopsis ====
 +
 +  * **test OP chaîne**
 +  * **[ OP chaîne ]**
 +  * **<​nowiki>​[[</​nowiki>​ OP chaîne <​nowiki>​]]</​nowiki>​**
 +
 +  * Avec :
 +    * **Chaîne** est sujette au développement des paramètres.
 +    * **OP**, l'un des opérateur du tableau suivant.
 +
 +|  Liste des primitives de test sur une chaîne ​ ||
 +^ Primitives ^ Retours ^
 +|**-z** | Vrai si **chaîne** de longueur nulle. |
 +|**-n** | Vrai si **chaîne** de longueur non nulle. |
 +
 +<​note>​
 +La primitive **-n** peut-être omis.
 +</​note>​
 +
 +==== Exemples ====
 +
 +Testons une chaîne vide.
 +
 +<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>​
 +0
 +1
 1 1
 </​file>​ </​file>​
 +
 +Testons une chaînes non vide.
 +
 +<code user>
 +test -z "​mot"​ ;​ echo $?
 +[[ -n "​Linux"​ ]] ; echo $?
 +[[ "GNU Linux" ]] ; echo $?
 +</​code><​code>​
 +1
 +0
 +0
 +</​code>​
 +
 +Testons la variable **v** si elle est, de longueur non nulle, nulle ou si elle n'​existe pas.
  
 <code user> <code user>
Ligne 90: Ligne 194:
 [ -n "​$v"​ ] ; echo $? [ -n "​$v"​ ] ; echo $?
  
-unset v # Supprime le paramètre v+unset v # Supprime le paramètre v (il n'​existe plus).
 [[ -z "​$v"​ ]] ; echo $? [[ -z "​$v"​ ]] ; echo $?
 +[ "​$v"​ ] ; echo $?
  
-</​code>​ +</​code><​file>​
-<​file ​config Retour des commandes>+
 1 1
 0 0
 0 0
 +1
 </​file>​ </​file>​
  
-=== 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 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. +Si sa valeur contient des espaces, il doit être protégé par des guillemets doubles. 
-<​code>​+ 
 +<​code ​user>
 p="​Debian Facile"​ p="​Debian Facile"​
 test -z $p ; echo $? test -z $p ; echo $?
  
 unset p unset p
-</​code>​ +</​code><​file>​
-<​file ​config Retour des commandes>+
 bash: test: Debian : opérateur binaire attendu bash: test: Debian : opérateur binaire attendu
 2 2
Ligne 116: Ligne 221:
  
 <​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>​
  
-Avec la commande **[** ou **test**, l'​opérateur **-n** ​revoie ​un code de retour inattendu, quand un paramètre vide est testé sans protection. +L'​opérateur **-n** ​renvoie ​un code de retour inattendu, quand un paramètre vide est testé sans protection.\\  
-<​code>​+Sauf avec la commande **<​nowiki>​[[</​nowiki>​**. 
 + 
 +<​code ​user>
 test -n $p ; echo $? test -n $p ; echo $?
 [ -n $p ] ; echo $? [ -n $p ] ; echo $?
Ligne 128: Ligne 235:
  
 unset p unset p
-</​code>​ +</​code><​file>​
-<​file>​+
 0 0
 0 0
Ligne 135: Ligne 241:
 </​file>​ </​file>​
  
-=== Bon usage ===+==== Astuces ====
  
-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 **+**.\\ ​+Avec la primitive ​**-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]]) (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>​+ 
 +<​code ​user>
 p="​Debian GNU Linux" p="​Debian GNU Linux"
  
-test -z ${p+x} ​; echo $? +test -z ${p+x} ; echo $?
-[ -z ${p+x} ] ; echo $? +
-[[ -z ${p+x} ]] ; echo $?+
  
 unset p unset p
-</​code>​ +[[ -z ${p+x} ]] ; echo $? 
-<​file ​config Retour de la commande>+</​code><​file>​
 1 1
 +0
 +</​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 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>​**.
 +
 +<code user>
 +p="​Debian Facile"​
 +
 +[[ -n ${p+x} ]] ; echo $?
 +[[ -${p+x} ]] ; echo $?
 +
 +unset p
 +[[ -n ${p+x} ]] ; echo $?
 +[[ -${p+x} ]] ; echo $?
 +</​code><​file>​
 +0
 +0
 1 1
 1 1
 </​file>​ </​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 ====+===== Comparaison ​entre deux chaînes ​=====
  
-Les commandes de test disposent ​d'​opérateurs ​binaires pour comparer deux chaînes entre elles.+Les commandes de test disposent ​de 5 primitives ​binaires pour comparer deux chaînes entre elles.
  
-Syntaxe ​+==== 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. +  * **test chaîne1 OP chaîne2** 
-Avec pour OP, l'un des opérateur du tableau suivant. +  * **[ chaîne1 ​OP chaîne2 ]** 
-</code>+  * **<​nowiki>​[[</​nowiki>​ chaîne1 OP chaîne2 <​nowiki>​]]</nowiki>**
  
-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.+  * 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>​
  
-|  ​Opérateurs ​de comparaison ​sur les chaînes ​ || +|  ​Listes des primitives ​de comparaison ​entre deux chaînes ​ || 
-Opérateurs Significations +Primitives Retours
-| ''​= ''​ | Correspond ​à +| ''​= ''​ | Vrai si **Chaîne1** correspond ​à **Chaîne2** .
-| ''​==''​ | Synonyme de =  +| ''​==''​ | Synonyme de **=**
-| ''​!=''​ | ​Ne correspond pas  +| ''​!=''​ | ​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 avant **chaine2**
-| ''>''​ | Vrai si chaine2 ​est placée lexicographiquement après chaine2 |+| ''>''​ | Vrai si **chaine1** ​est placée lexicographiquement après ​**chaine2** |
  
-=== Exemples ===+==== Exemples ​====
  
 <note important>​ <note important>​
Ligne 189: Ligne 314:
 [[ "​$a"​ < "​$b"​ ]] # vrai si $a se trouve avant $b dans le dictionnaire [[ "​$a"​ < "​$b"​ ]] # vrai si $a se trouve avant $b dans le dictionnaire
 </​code>​ </​code>​
-__ +__-posix :__
--posix :__+
  
 <​code>​ <​code>​
Ligne 199: Ligne 323:
  
 <code user> <code user>
-test1+test "​GNU" ​== "​GNU"​ ] ; echo $? 
--n "$test1" ] +["GNU" != "GNU Linux" ]] ; echo $? 
-echo $? +</​code><​file>​ 
- +
-unset test1 +0
-</​code>​ +
-<​file ​config Retour de la commande+
-1+
 </​file>​ </​file>​
  
->Donc la chaîne ​de la variable test1 est égale ​à zéro.+>Donc la chaîne ​"​GNU" ​est identique ​à elle-même ;), mais pas à "GNU Linux".
  
 <code user> <code user>
-test2=abc +v1="​Debian GNU Linux" 
-test3=ab +v2="​Debian Facile"​ 
-[ "$test2" = "$test3" ] +if [ "$v1" = "$v2" ]  
-echo $?+then 
 + echo '​vrai'​ 
 +else 
 + echo '​faux'​ 
 +fi
  
-unset test2 test3 +unset v1 v2 
-</​code>​ +</​code><​file>​ 
-<​file ​config retour de la commande+faux
-+
 </​file>​ </​file>​
  
->Donc les deux chaînes ​contenue ​dans les variables ​test2 et test3 ne sont pas égales.+>Donc les deux chaînes ​contenues ​dans les variables ​v1 et v2 ne sont pas égales.
  
-=== Exemples ​dans un script ===+Copions le code suivant ​dans le fichier **mon_script**.
  
 <code bash mon_script>​ <code bash mon_script>​
Ligne 231: Ligne 355:
 var1="​def"​ var1="​def"​
 var2="​def"​ var2="​def"​
-if [ $var1 == $var2 ] ; then +if [ "$var1" ​== "$var2" ​] ; then 
-   echo "1)test de correspondance chaîne de caractères sur valeur de variable: ​\$var1:"$var1" ​correspond(==) à \$var2:"$var2"."+   echo "1) \$var1 ​($var1correspond(==) à \$var2 ​($var2)."
 fi fi
    
 var3="​hip"​ var3="​hip"​
 var4="​hip"​ var4="​hip"​
-if test $var3 = $var4  ; then +if test "$var3" ​"$var4" ​ ; then 
-   echo "​2) ​test de correspondance chaîne de caractères sur valeur de variable: ​\$var3:"$var3" ​correspond(=) à \$var4:"$var4"."+   echo "2) \$var3 ​($var3correspond(=) à \$var4 ​($var4)."
 fi fi
-</​code> ​ +</​code><​code user> 
- +bash mon_script
-<code user> +
-bash mon-script+
  
 rm -v mon_script rm -v mon_script
-</​code>​ +</​code><​file>​ 
-<​file ​config retour de la commande+1) $var1 (defcorrespond(==) à $var2 (def)
-1) test de correspondance chaîne de caractères sur valeur de variable: ​$var1:def correspond(==) à $var2:def. +2) $var3 (hipcorrespond(=) à $var4 (hip).
-2) test de correspondance chaîne de caractères sur valeur de variable: ​$var3:hip correspond(=) à $var4:hip.+
 '​mon_script'​ supprimé '​mon_script'​ supprimé
 </​file>​ </​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>​ <note important>​
-Attention de ne pas confondre les opérateurs ​de comparaison sur les chaînes ​de caractère ​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 ​symboles (mais avec la syntaxe doubles parenthèses et surtout pas de crochets).\\+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>​ </​note>​
  
-<​code ​bash script> +<​code ​usert>
-#!/bin/bash+
 a="​sloiuy"​ a="​sloiuy"​
 b="​aktgjaùkjayaj"​ b="​aktgjaùkjayaj"​
 +
 if [[ $a < $b ]] ; then  if [[ $a < $b ]] ; then 
    echo "OK l'​opérateur < fonctionne avec les chaînes de caractère"​    echo "OK l'​opérateur < fonctionne avec les chaînes de caractère"​
 fi fi
-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 " "+
 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><​file>​
-<code user>​./​mon_script</​code>​ +
-<​file ​config retour de la commande>+
 OK L'​opérateur < fonctionne avec les chaînes de caractère 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)
Ligne 280: Ligne 402:
 </​file>​ </​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.
 +
 +----
 +|[[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===== ===== Tests sur les 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