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 →
Ci-dessous, les différences entre deux révisions de la page.
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 [20/02/2023 13:29] agp91 [Opérateurs sur les chaînes] |
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [21/02/2023 02:15] agp91 [Comparaison entre deux chaînes] |
||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
- | ======Bash : les opérateurs lexicographiques ====== | + | ====== Bash : Les opérateurs de test sur chaînes ====== |
- | * Objet : suite de la série de wiki visant à maîtriser bash via les différents caractère spéciaux. | + | * Objet : Suite de la série de wiki visant à maîtriser bash via les caractères. |
- | * Niveau requis : {{tag>débutant avisé}} | + | * 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 : | + | * Suivi : {{tag>à-tester}} |
* 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 | ||
+ | * Modifié par [[user|agp91]] le 21/02/2022 | ||
* 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 13: | Ligne 15: | ||
* [[doc:programmation:shells:bash-les-differents-caracteres-speciaux|Vision d'ensemble]] | * [[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]] | * [[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-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-iv-symboles-dans-les-calculs-mathematiques|Les symboles dans les calculs]] | ||
Ligne 19: | Ligne 23: | ||
* [[doc:programmation:shells:man-bash-vi-les-caracteres-de-transformation-de-parametres|Les caractères de transformation de parametres]] | * [[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]] | * [[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 les paramètres ===== | ||
- | |||
- | Les commandes de test disposent de deux opérateurs unaires pour tester les paramètres. | ||
- | |||
- | <code> | ||
- | test OP nom_paramètre | ||
- | [ OP nom_paramètre ] | ||
- | [[ OP nom_paramètre ]] | ||
- | |||
- | Chaîne est sujette au développement des paramètres. | ||
- | Avec pour OP, l'un des opérateur du tableau suivant. | ||
- | </code> | ||
- | |||
- | | Opérateurs sur paramètre || | ||
- | ^ Opérateurs ^ Retours ^ | ||
- | |''-v'' | Vrai si le paramètre existe | | ||
- | |''-R'' | Vrai si le paramètre est une référence de nom | | ||
- | |||
- | |||
- | ==== Exemples ==== | ||
- | |||
- | Testons si le paramètre var existe. | ||
- | |||
- | <code user> | ||
- | var="Debian Facile" # var existe et n'est pas une chaîne vide | ||
- | [ -v var ] ; echo $? | ||
- | |||
- | 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> | ||
- | <file> | ||
- | 0 | ||
- | 0 | ||
- | 1 | ||
- | </file> | ||
- | |||
- | __Rappel :__ Une référence de nom est un paramètre qui mémorise le nom d'un autre paramètre.\\ | ||
- | Il est nécessaire d'utilisé la commande **declare -n** pour construire une référence de nom. | ||
- | |||
- | <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> | ||
- | <file config Retour des commandes> | ||
- | var=Debian GNU Linux | ||
- | v=Debian GNU Linux | ||
- | var=Debian Facile | ||
- | 1 | ||
- | 0 | ||
- | declare -- var="Debian Facile" | ||
- | declare -n v="var" | ||
- | </file> | ||
- | |||
- | ====== Les opérateurs de test sur chaînes ====== | ||
===== Introduction ===== | ===== Introduction ===== | ||
Ligne 113: | Ligne 30: | ||
</note> | </note> | ||
- | Bash dispose de plusieurs commandes pour réaliser des tests sur des paramètres. | + | Bash dispose de plusieurs commandes pour **réaliser des tests sur des chaînes de carractères**. |
* Les commandes internes **[** et **test**. | * Les commandes internes **[** et **test**. | ||
Ligne 132: | Ligne 49: | ||
* 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. | * 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> | </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) ===== | ===== Tester une chaîne (vide ou pas) ===== | ||
Ligne 140: | Ligne 54: | ||
Les commandes de test disposent de deux opérateurs unaires pour tester si une chaîne est vide (de longueur nulle) 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 ==== | + | ==== Syntaxe ==== |
- | * **test OP chaîne** | + | * **test OP** [**"**]**chaîne**[**"**] |
- | * **[ OP chaîne ]** | + | * **[ OP** [**"**]**chaîne**[**"**] **]** |
- | * **<nowiki>[[</nowiki> OP chaîne <nowiki>]]</nowiki>** | + | * **<nowiki>[[</nowiki> OP** [**"**]**chaîne**[**"**] **<nowiki>]]</nowiki>** |
* Avec : | * Avec : | ||
* **Chaîne** est sujette au développement des paramètres. | * **Chaîne** est sujette au développement des paramètres. | ||
- | * **OP**, l'un des opérateur du tableau suivant. | + | * **OP**, l'une des primitives du tableau suivant. |
- | | Liste des primitives de test sur une chaîne || | + | | Liste des primitives de test sur chaîne || |
- | ^ Primitives ^ Retours ^ | + | ^ Primitives ^ Retours ^ |
- | |**-z** | Vrai si **chaîne** de longueur nulle. | | + | |''-z'' | Vrai si chaîne de longueur nulle | |
- | |**-n** | Vrai si **chaîne** de longueur non nulle. | | + | |''-n'' | Vrai si chaîne de longueur non nulle | |
<note> | <note> | ||
- | La primitive **-n** peut-être omis. | + | * Si l'opérande (**chaîne**) contient des espaces, il doit être protégé. |
+ | * La primitive **-n** peut-être omis. | ||
</note> | </note> | ||
==== Exemples ==== | ==== Exemples ==== | ||
- | |||
- | Testons une chaîne vide. | ||
<code user> | <code user> | ||
Ligne 172: | Ligne 85: | ||
1 | 1 | ||
</file> | </file> | ||
- | |||
- | Testons une chaînes non vide. | ||
<code user> | <code user> | ||
Ligne 179: | Ligne 90: | ||
[[ -n "Linux" ]] ; echo $? | [[ -n "Linux" ]] ; echo $? | ||
[[ "GNU Linux" ]] ; echo $? | [[ "GNU Linux" ]] ; echo $? | ||
- | </code><code> | + | </code><file> |
1 | 1 | ||
0 | 0 | ||
0 | 0 | ||
- | </code> | + | </file> |
- | + | ||
- | Testons la variable **v** si elle est, de longueur non nulle, nulle ou si elle n'existe pas. | + | |
<code user> | <code user> | ||
Ligne 194: | Ligne 103: | ||
[ -n "$v" ] ; echo $? | [ -n "$v" ] ; echo $? | ||
- | unset v # Supprime le paramètre v (il n'existe plus). | + | unset v # Supprime le paramètre v |
[[ -z "$v" ]] ; echo $? | [[ -z "$v" ]] ; echo $? | ||
[ "$v" ] ; echo $? | [ "$v" ] ; echo $? | ||
Ligne 207: | Ligne 116: | ||
==== 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 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 doubles. | + | 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> | <code user> | ||
Ligne 219: | Ligne 129: | ||
2 | 2 | ||
</file> | </file> | ||
- | |||
<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> | ||
- | L'opérateur **-n** renvoie un code de retour inattendu, quand un paramètre vide est testé sans protection.\\ | + | La directive **-n** revoie un code de retour inattendu, quand un paramètre vide est testé sans protection.\\ |
Sauf avec la commande **<nowiki>[[</nowiki>**. | Sauf avec la commande **<nowiki>[[</nowiki>**. | ||
Ligne 243: | Ligne 152: | ||
==== Astuces ==== | ==== Astuces ==== | ||
- | Avec la primitive **-z**, nous pouvons nous affranchir de la protection des guillemets en utilisant __le remplacement des paramètre__ et l'opérateur **+**.\\ | + | 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]]) | (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> | <code user> | ||
p="Debian GNU Linux" | p="Debian GNU Linux" | ||
Ligne 258: | Ligne 166: | ||
</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**). | + | 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>**. | + | 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> | <code user> | ||
Ligne 266: | Ligne 174: | ||
[[ -n ${p+x} ]] ; echo $? | [[ -n ${p+x} ]] ; echo $? | ||
- | [[ -${p+x} ]] ; echo $? | + | [[ ${p+x} ]] ; echo $? |
unset p | unset p | ||
[[ -n ${p+x} ]] ; echo $? | [[ -n ${p+x} ]] ; echo $? | ||
- | [[ -${p+x} ]] ; echo $? | + | [[ ${p+x} ]] ; echo $? |
</code><file> | </code><file> | ||
0 | 0 | ||
Ligne 381: | Ligne 289: | ||
</note> | </note> | ||
- | <code usert> | + | <code user> |
a="sloiuy" | a="sloiuy" | ||
b="aktgjaùkjayaj" | b="aktgjaùkjayaj" | ||
Ligne 416: | Ligne 324: | ||
echo $? | echo $? | ||
</code><file> | </code><file> | ||
- | echo $? | ||
bash: test: GNU : opérateur unaire attendu | bash: test: GNU : opérateur unaire attendu | ||
2 | 2 | ||
Ligne 435: | Ligne 342: | ||
N'étant pas nulle, le test n'échoue pas. | 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===== | ||
- | |||
- | 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).). | ||
- | |||
- | <code bash> | ||
- | if [[ option $FICHIER ]] | ||
- | </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.| | ||
- | |||
- | Remarque : L'opérateur **-e** teste si le fichier existe quelque soit son statut (fichier, répertoire, lien, etc). | ||
- | |||
- | ==== Test dans un script ==== | ||
- | Soit le script mon_script. | ||
- | <code bash script> | ||
- | #!/bin/bash | ||
- | var1="~/toto" | ||
- | if [ -f "$var1" ] | ||
- | then | ||
- | echo "le fichier existe !" | ||
- | else | ||
- | 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 | ||
- | |||
- | var1="home/hypathie/toto" | ||
- | if [ -f "$var1" ] | ||
- | then | ||
- | echo "le fichier existe !" | ||
- | else | ||
- | echo "fichier inexistant !" | ||
- | fi | ||
- | |||
- | if test -f "$var1" | ||
- | then | ||
- | echo "le fichier existe !" | ||
- | else | ||
- | echo "fichier inexistant !" | ||
- | fi | ||
- | </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> | ||
- | |||
- | ==== Tests en ligne de commande ==== | ||
- | Tests dans un terminal des commande **test** et **[**. | ||
- | |||
- | <code user> | ||
- | touch ~/toto | ||
- | |||
- | test -f /home/hypathie/toto | ||
- | echo $? | ||
- | |||
- | [ -f ~/toto ] | ||
- | echo $? | ||
- | |||
- | rm -v ~/toto | ||
- | </code> | ||
- | <file retour de la commande> | ||
- | 0 | ||
- | 0 | ||
- | '/home/hypathie/toto' supprimé | ||
- | </file> | ||
- | |||
- | Et voilà ! 8-) | ||
=====Tuto précédent ===== | =====Tuto précédent ===== | ||
- | [[doc:programmation:shells: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 ===== | ||
- | [[doc:programmation:shells: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]] |