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 [13/02/2023 11:15] agp91 [Caractères de comparaison sur les chaînes de caractères] |
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [16/02/2023 18:37] agp91 [Caractères de comparaison sur les chaînes de caractères] |
||
---|---|---|---|
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 | ||
+ | |||
* 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 18: | 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. | ||
+ | |||
+ | | Opérateurs de comparaison sur les chaînes || | ||
+ | ^ Opérateurs ^ Significations ^ | ||
+ | | ''= '' | Correspond à | | ||
+ | | ''=='' | Synonyme de = | | ||
+ | | ''!='' | Ne correspond pas | | ||
+ | | ''<'' | Vrai si chaine1 est placée lexicographiquement avant chaine2 | | ||
+ | | ''>'' | Vrai si chaine2 est placée lexicographiquement après chaine2 | | ||
C'est pourquoi on trouve souvent les options ''-z'' et ''-n'' du tableau ci-dessous, ajoutées au tableau ci-dessus : | C'est pourquoi on trouve souvent les options ''-z'' et ''-n'' du tableau ci-dessous, ajoutées au tableau ci-dessus : | ||
- | ^ Condition ^ Signification ^ | ||
- | |''-z'' $chaine | ne contient rien | | ||
- | |''-n'' $chaine | contient quelque-chose | | ||
<note important> | <note important> | ||
Ligne 162: | Ligne 207: | ||
===== Tests sur les fichiers===== | ===== Tests sur les fichiers===== | ||
- | *Le shell bash | + | 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).). |
- | + | ||
- | > Il permet d'effectuer aussi des comparaisons sur les fichiers avec les commandes internes et composées ''<nowiki>[[ ]]</nowiki>'' et ''<nowiki>[ ]</nowiki>'' (associées à IF ou non). | + | |
- | > | + | |
- | > Les commandes ''<nowiki>[[ ]]</nowiki>'' et ''<nowiki>[ ]</nowiki>'' suppléent la commande test. | + | |
<code bash> | <code bash> | ||
Ligne 172: | Ligne 213: | ||
</code> | </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.| | ||
- | ^ options de test ^ vérifie si : ^ | + | Remarque : L'opérateur **-e** teste si le fichier existe quelque soit son statut (fichier, répertoire, lien, etc). |
- | |''-e'' $nomfichier | le fichier existe | | + | |
- | |''-d'' $nomfichier | le fichier est un répertoire | | + | |
- | |''-f'' $nomfichier | le fichier est un document | | + | |
- | |''-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) | | + | |
- | * Avec commande test ou crochets : | + | ==== Test dans un script ==== |
- | (Soit le fichier ordinaire "toto" dans le répertoire courant de l'utilisateur) | + | Soit le script mon_script. |
<code bash script> | <code bash script> | ||
#!/bin/bash | #!/bin/bash | ||
Ligne 193: | Ligne 251: | ||
echo "le fichier existe !" | echo "le fichier existe !" | ||
else | else | ||
- | echo "fichier inexistant: le fichier existe mais dans un script il faut le chemin absolu du fichier testé !" | + | 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 | fi | ||
Ligne 203: | Ligne 269: | ||
echo "fichier inexistant !" | echo "fichier inexistant !" | ||
fi | fi | ||
- | echo " " | + | |
- | var2="home/hypathie/toto" | + | if test -f "$var1" |
- | if test -f "$var2" | + | |
then | then | ||
echo "le fichier existe !" | echo "le fichier existe !" | ||
Ligne 212: | Ligne 277: | ||
fi | fi | ||
</code> | </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> | ||
- | * Les tests sur les fichiers dans le terminal avec commande test : | + | ==== Tests en ligne de commande ==== |
- | (Soit le fichier ordinaire "toto") | + | Tests dans un terminal des commande **test** et **[**. |
<code user> | <code user> | ||
+ | touch ~/toto | ||
+ | |||
test -f /home/hypathie/toto | test -f /home/hypathie/toto | ||
- | #puis | ||
echo $? | echo $? | ||
- | </code> | + | |
- | <file config retour de la commande> | + | |
- | 0 | + | |
- | </file> | + | |
- | * Les tests sur les fichiers dans le terminal avec les crochets : | + | |
- | <code user> | + | |
[ -f ~/toto ] | [ -f ~/toto ] | ||
- | #puis | ||
echo $? | echo $? | ||
- | </code> | + | |
- | <file config retour de la commande> | + | rm -v ~/toto |
- | 0 | + | </code> |
+ | <file retour de la commande> | ||
+ | 0 | ||
+ | 0 | ||
+ | '/home/hypathie/toto' supprimé | ||
</file> | </file> | ||
+ | |||
Et voilà ! 8-) | 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]] | [[doc:programmation:shells:la-page-man-bash-les-caracteres-speciaux|Bash : Détail et caractères]] | ||
- | ====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]] | [[doc:programmation:shells:page-man-bash-iii-les-operateurs-de-comparaison-numerique|Bash : les opérateurs de comparaison numérique]] |