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 [15/02/2023 22:20] agp91 [Bash : les opérateurs lexicographiques] |
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [16/02/2023 19:07] agp91 [Introduction] |
||
---|---|---|---|
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 ===== | ||
- | ===== Caractères de comparaison sur les chaînes de caractères ===== | + | En interne, bash dispose de plusieurs commandes pour réaliser des tests sur les chaînes : |
- | * Le shell bash utilise les opérateurs booléens sur les chaînes de caractère : ''=='', ''!='' , ''<'' , ''>'' et ''='' , | + | *Les commandes **[** et **test**. |
- | * contexte : conditions voir man bash | + | *Et la commande composée **<nowiki>[[</nowiki>**. |
- | ^ Condition ^ Signification ^ | + | Les commandes **[** et **test** sont disponibles dans leurs versions externe : **/usr/bin/[** et **/usr/bin/test**.\\ |
- | |$chaine1 ''= ''$chaine2 | correspond à | | + | Elles ont toutes les deux la même page de manuel (**man [** ou **man test**).\\ |
- | |$chaîne1 ''=='' $chaîne2 | synonyme de = | | + | Les commandes internes disposent des opérateurs que n'ont pas les commandes externes. |
- | |$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 | | + | |
+ | __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. | ||
- | > 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. | ||
+ | ===== Test sur chaîne (vide ou pas) ===== | ||
+ | |||
+ | Les commandes de test disposent d'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 | | ||
+ | |||
+ | ===== Comparaison de chaînes ===== | ||
+ | |||
+ | Les commandes de test disposent d'opérateurs binaires pour comparer deux chaînes entre elles. | ||
+ | |||
+ | 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. | ||
+ | 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> | ||
Ligne 197: | Ligne 237: | ||
|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.| | |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 test si le fichier existe quelque soit son statut (fichier, répertoire, lien, etc). | + | Remarque : L'opérateur **-e** teste si le fichier existe quelque soit son statut (fichier, répertoire, lien, etc). |
==== Test dans un script ==== | ==== Test dans un script ==== |