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 | ||
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [31/05/2014 17:07] Hypathie [Opérateurs lexicographiques] |
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [30/04/2023 01:23] arpinux lien mort : page utilisateur absente |
||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
- | ======Bash : les opérateurs lexicographiques ====== | ||
- | * Objet : suite de la série de wiki visant à maîtriser bash via les différents caractère spéciaux. | + | ====== Bash : Les opérateurs de test sur chaînes ====== |
+ | |||
+ | * Objet : Suite de la série de wiki visant à maîtriser bash via les caractères. | ||
* Niveau requis : {{tag>débutant}} | * 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 : {{à-placer}} - | + | * Suivi : {{tag>à-tester}} |
- | * Création par **Hypathie** 08/04/2014 | + | * Création par [[user>Hypathie]] le 08/04/2014 |
- | * Testé par <Hypathie> le <Avril 2014> | + | * Testé par [[user>Hypathie]] en Avril 2014 |
- | * Commentaires sur le forum : [[https://debian-facile.org/viewtopic.php?pid=87499#p87499 | Lien vers le forum concernant ce tuto]] ((N'hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !)) | + | * Modifié par **agp91** le 21/02/2022 |
- | **RAPPEL DU PLAN DE LA SÉRIE : **\\ | + | * 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 !)) |
- | 1) Intro I : [[atelier:chantier:bash-les-differents-caracteres-speciaux|Bash : Introduction]]\\ | + | * [[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]] | ||
+ | * [[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-iv-symboles-dans-les-calculs-mathematiques|Les symboles dans les calculs]] | ||
+ | * [[doc:programmation:shells:page-man-bash-v-les-tableaux|Bash : les tableaux]] | ||
+ | * [[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]] | ||
- | 2) chap II : [[atelier:chantier:la-page-man-bash-les-caracteres-speciaux|Bash : Détail et caractères]]\\ | + | ===== Introduction ===== |
- | 3) chap III : C'est ici !\\ | + | <note> |
+ | Dans la page du manuel de bash, **les opérateurs des commandes de test** sont nommés __**primitives**__. | ||
+ | </note> | ||
- | 4) chap IV : [[atelier:chantier:page-man-bash-iii-les-operateurs-de-comparaison-numerique|Bash : les opérateurs de comparaison numérique]]\\ | + | Bash dispose de plusieurs commandes pour **réaliser des tests sur des chaînes de caractères**. |
- | 5) chap V : [[atelier:chantier:page-man-bash-iv-symboles-dans-les-calculs-mathematiques|Bash : les symboles dans les calculs]]\\ | + | * 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 primitives que n'ont pas les commandes externes. | ||
+ | </note> | ||
- | 6) chap VI : [[atelier:chantier:page-man-bash-v-les-tableaux|Bash : les tableaux]]\\ | + | <note> |
+ | __Rappels :__ | ||
- | 7) chap VII : [[atelier:chantier:man-bash-vi-les-caracteres-de-transformation-de-parametres|Bash : les caractères de transformation de parametres]]\\ | + | * Une commande de test renvoie le code de retour 0 (considéré comme vrai) lorsque le test réussi et 1 (considéreé 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> | ||
- | 8) chap VIII : [[atelier:chantier:bash-vii-globs-etendus-regex|Bash : globs étendus et regex]] | + | ===== 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. | ||
- | =====Opérateurs lexicographiques ===== | + | ==== Syntaxe ==== |
- | ====1) Caractères de comparaison sur les chaînes de caractères ==== | + | * **test OP** [**"**]**chaîne**[**"**] |
- | *Le shell bash utilise les opérateurs booléens sur les chaînes de caractère : == , != , < , > , >=, <= , | + | * **[ OP** [**"**]**chaîne**[**"**] **]** |
- | *contexte : conditions (voir man bash lignes 2498-2513 | + | * **<nowiki>[[</nowiki> OP** [**"**]**chaîne**[**"**] **<nowiki>]]</nowiki>** |
- | ^ Condition ^ Signification ^ | + | * Avec : |
- | |$chaine1 = $chaine2 | est égal | | + | * **Chaîne** est sujette au développement des paramètres. |
- | |$chaîne1 == $chaîne2 | synonyme de = | | + | * **OP**, l'une des primitives du tableau suivant. |
- | |$chaine1 != $chaine2 | n'est pas égal à | | + | |
- | |$chaine1 < $chaîne2 | avant (selon l'ordre alphabétique ASCII) | | + | |
- | |$chaine1 > $chaîne2 | après (ASCII) | | + | |
- | |$chaine >= $chaine | de longueur égale ou plus grande | | + | |
- | |$chaine <= | de longueur égale ou plus petite | | + | |
- | *Pour effectuer des comparaisons sur les chaînes de caractère((Voir Man bash ligne 2410 et man test ligne 39)) : les options -z et -a sont communes aux deux cas suivants : | + | | Liste des primitives de test sur chaîne || |
- | <code> | + | ^ Primitives ^ Retours ^ |
- | Le shell bash utilise les commandes internes et composées [[ ]] ou [ ] | + | |''-z'' | Vrai si chaîne de longueur nulle | |
- | (souvent utilisées avec IF) pour les comparaisons de chaînes de caractères. | + | |''-n'' | Vrai si chaîne de longueur non nulle | |
- | </code> | + | |
+ | <note> | ||
+ | * Si l'opérande (**chaîne**) contient des espaces, il doit être protégé. | ||
+ | * La primitive **-n** peut-être omis. | ||
+ | </note> | ||
+ | |||
+ | ==== Exemples ==== | ||
+ | |||
+ | <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 | ||
+ | </file> | ||
+ | |||
+ | <code user> | ||
+ | test -z "mot" ; echo $? | ||
+ | [[ -n "Linux" ]] ; echo $? | ||
+ | [[ "GNU Linux" ]] ; echo $? | ||
+ | </code><file> | ||
+ | 1 | ||
+ | 0 | ||
+ | 0 | ||
+ | </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 $? | ||
+ | [ "$v" ] ; echo $? | ||
+ | |||
+ | </code><file> | ||
+ | 1 | ||
+ | 0 | ||
+ | 0 | ||
+ | 1 | ||
+ | </file> | ||
+ | |||
+ | ==== Mauvais usages ==== | ||
+ | |||
+ | 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 simple ou doubles.\\ | ||
+ | __Rappel__ : Les guillemets simple ne permettent le remplacement des paramètres. | ||
+ | |||
+ | <code user> | ||
+ | p="Debian Facile" | ||
+ | test -z $p ; echo $? | ||
+ | |||
+ | unset p | ||
+ | </code><file> | ||
+ | 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> | ||
+ | |||
+ | La directive **-n** revoie un code de retour inattendu, quand un paramètre vide est testé sans protection.\\ | ||
+ | Sauf avec la commande **<nowiki>[[</nowiki>**. | ||
+ | |||
+ | <code user> | ||
+ | test -n $p ; echo $? | ||
+ | [ -n $p ] ; echo $? | ||
+ | |||
+ | p="" | ||
+ | [[ -n $p ]] ; echo $? | ||
+ | |||
+ | unset p | ||
+ | </code><file> | ||
+ | 0 | ||
+ | 0 | ||
+ | 1 | ||
+ | </file> | ||
+ | |||
+ | ==== Astuces ==== | ||
+ | |||
+ | 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]]) | ||
+ | <code user> | ||
+ | p="Debian GNU Linux" | ||
+ | |||
+ | test -z ${p+x} ; echo $? | ||
+ | |||
+ | unset p | ||
+ | [[ -z ${p+x} ]] ; echo $? | ||
+ | </code><file> | ||
+ | 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 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> | ||
+ | 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 | ||
+ | </file> | ||
+ | |||
+ | ===== Comparaison entre deux chaînes ===== | ||
+ | |||
+ | Les commandes de test disposent de 5 primitives binaires pour comparer deux chaînes entre elles. | ||
+ | |||
+ | ==== Syntaxe ==== | ||
+ | |||
+ | * **test chaîne1 OP chaîne2** | ||
+ | * **[ chaîne1 OP chaîne2 ]** | ||
+ | * **<nowiki>[[</nowiki> chaîne1 OP chaîne2 <nowiki>]]</nowiki>** | ||
+ | |||
+ | * 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> | ||
+ | |||
+ | | Listes des primitives de comparaison entre deux chaînes || | ||
+ | ^ Primitives ^ Retours ^ | ||
+ | | ''= '' | Vrai si **Chaîne1** correspond à **Chaîne2** . | | ||
+ | | ''=='' | Synonyme de **=** | | ||
+ | | ''!='' | 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 après **chaine2** | | ||
- | C'est pourquoi on trouve souvent les options -z et -a du tableau ci-dessous, ajoutées au tableau ci-dessus : | + | ==== Exemples ==== |
- | ^ Condition ^ Signification ^ | + | |
- | |-z $chaine | ne contient rien | | + | |
- | |-n $chaine | contient quelque-chose | | + | |
<note important> | <note important> | ||
Ligne 59: | Ligne 220: | ||
[[ $a == "z*" ]] # vrai si $a est égal à z* | [[ $a == "z*" ]] # vrai si $a est égal à z* | ||
[[ $a == z* ]] # vrai si $a commence avec un "z" (reconnaissance de modèles) | [[ $a == z* ]] # vrai si $a commence avec un "z" (reconnaissance de modèles) | ||
- | if [[ "$a" < "$b" ]] | + | [[ "$a" < "$b" ]] # vrai si $a se trouve avant $b dans le dictionnaire |
</code> | </code> | ||
- | __ | + | __-posix :__ |
- | -posix :__ | + | |
<code> | <code> | ||
- | [ "$a" == "z*" ] # vrai si $a est égal à z* | + | [ "$a" = "z*" ] # vrai si $a est égal à z* |
- | if [ "$a" \< "$b" ] | + | [ "$a" \< "$b" ] # vrai si $a se trouve avant $b dans le dictionnaire |
</code> | </code> | ||
</note> | </note> | ||
- | ===remarques:=== | ||
- | **1) Dans le terminal, crochets ou commande test:** | ||
<code user> | <code user> | ||
- | test1= | + | test "GNU" == "GNU" ] ; echo $? |
- | #puis | + | [[ "GNU" != "GNU Linux" ]] ; echo $? |
- | [ -n "$test1" ] | + | </code><file> |
- | #puis | + | 0 |
- | echo $? | + | 0 |
- | </code> | + | </file> |
- | Retour: | + | >Donc la chaîne "GNU" est identique à elle-même ;), mais pas à "GNU Linux". |
- | + | ||
- | <code> | + | |
- | 1 # Donc la chaîne de la variable test1 est égale à zéro. | + | |
- | </code> | + | |
- | + | ||
- | * autre exemple : | + | |
<code user> | <code user> | ||
- | test2=abc | + | v1="Debian GNU Linux" |
- | #puis | + | v2="Debian Facile" |
- | test3=ab | + | if [ "$v1" = "$v2" ] |
- | #puis | + | then |
- | [ "$test2" = "$test3" ] | + | echo 'vrai' |
- | #puis | + | else |
- | echo $? | + | echo 'faux' |
- | </code> | + | fi |
- | retour : | + | unset v1 v2 |
+ | </code><file> | ||
+ | faux | ||
+ | </file> | ||
- | <code> | + | >Donc les deux chaînes contenues dans les variables v1 et v2 ne sont pas égales. |
- | 1 # Donc les deux chaînes de valeur contenue dans les variables test2 et test3 ne sont pas égales. | + | |
- | </code> | + | |
- | **2) Dans les scripts c'est pareil ! ** | + | Copions le code suivant dans le fichier **mon_script**. |
- | * tests avec les crochets : | + | |
- | <code bash> | + | <code bash mon_script> |
#!/bin/bash | #!/bin/bash | ||
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 ($var1) correspond(==) à \$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 ($var3) correspond(=) à \$var4 ($var4)." |
fi | fi | ||
- | </code> | + | </code><code user> |
+ | bash mon_script | ||
- | Retour de ./mon-script : | + | rm -v mon_script |
+ | </code><file> | ||
+ | 1) $var1 (def) correspond(==) à $var2 (def). | ||
+ | 2) $var3 (hip) correspond(=) à $var4 (hip). | ||
+ | 'mon_script' supprimé | ||
+ | </file> | ||
- | <code> | + | Les commandes de test permettent de réaliser des test de comparaison lexicographique.\\ |
- | 1)test de correspondance chaîne de caractères sur valeur de variable: def:def correspond(==) à $var2:def. | + | (voir [[https://debian-facile.org/atelier:chantier:bash-comparaison-lexicographique-des-chaines|https://debian-facile.org/atelier:chantier:bash-comparaison-lexicographique-des-chaines]].) |
- | 2) test de correspondance chaîne de caractères sur valeur de variable: hip:hip correspond(=) à $var4:hip. | + | |
- | </code> | + | |
- | * tests avec la commande test | + | <note important> |
+ | 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> | ||
<code user> | <code user> | ||
- | test4=tout-compris | ||
- | #puis | ||
- | test5=toutcompris | ||
- | #puis | ||
- | test $test4 = $test5 | ||
- | #puis | ||
- | echo $? | ||
- | </code> | ||
- | |||
- | retour : | ||
- | |||
- | <code> | ||
- | 1 #donc les chaînes des deux valeurs sont différentes. | ||
- | </code> | ||
- | |||
- | **3) Attention de ne pas confondre les opérateurs de comparaison sur les chaînes de caractère avec les [[atelier:chantier:page-man-bash-iii-les-operateurs-de-comparaison-numerique#operateurs-booleens-de-comparaison-numerique|opérateurs booléens de comparaison numérique]] qui utilisent les mêmes symboles (mais avec la syntaxe doubles parenthèses et surtout pas de crochets).\\ ** | ||
- | |||
- | <code bash> | ||
- | #!/bin/bash | ||
a="sloiuy" | a="sloiuy" | ||
b="aktgjaùkjayaj" | b="aktgjaùkjayaj" | ||
+ | |||
if [[ $a < $b ]] ; then | if [[ $a < $b ]] ; then | ||
- | echo " " | + | echo "OK l'opérateur < fonctionne avec les chaînes de caractère" |
fi | fi | ||
- | echo "OK l'opérateur < fonctionne avec les chaînes de caractère" | + | |
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> |
- | Retour de ./mon-script : | + | OK L'opérateur < fonctionne avec les chaînes de caractère |
- | <code> | + | Les opérateurs < et > signifient avant et après selon l'ordre alphabétique (doubles crochets) |
- | 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 (simples crochets) |
- | Les opérateurs < et > signifient avant et après selon l'ordre alphabétique (doubles crochets) | + | </file> |
- | + | ||
- | Les opérateurs < et > signifient avant et après selon l'ordre alphabétique (simples crochets) | + | |
- | </code> | + | |
+ | <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> | ||
- | ====2) Tests sur les fichiers==== | + | ==== Mauvais usages ==== |
- | *Le shell bash | + | Les deux opérandes sont obligatoires. |
- | <code> | + | |
- | Il permet d'effectuer aussi des comparaisons sur les fichiers avec | + | |
- | les commandes internes et composées [[ ]] et [ ]] | + | |
- | (associées à IF ou non). | + | |
- | Les commandes [[ ]] et [ ] suppléent la commande test. | + | |
- | </code> | + | |
- | <code> | + | <code user> |
- | if [[ option $FICHIER ]] | + | test GNU == ; echo $? |
- | </code> | + | [[ != LINUX ]] |
- | + | echo $? | |
+ | </code><file> | ||
+ | bash: test: GNU : opérateur unaire attendu | ||
+ | 2 | ||
+ | bash: opérateur binaire conditionnel attendu | ||
+ | bash: erreur de syntaxe près de « LINUX » | ||
+ | 2 | ||
+ | </file> | ||
- | ^ test ^ vérifie si : ^ | + | Les espaces entre les opérandes et la primitive sont obligatoires. |
- | |-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) | | + | |
- | *Remarque 1 : | + | <code user> |
- | **Avec commande test ou crochets** | + | [ "GNU Linux"=="LINUX" ] ; echo $? |
- | (Soit le fichier ordinaire "toto" dans le répertoire courant de l'utilisateur) | + | </code><file> |
- | <code bash> | + | 0 |
- | #!/bin/bash | + | </file> |
- | var1="~/toto" | + | |
- | if [ -f "$var1" ] | + | |
- | then | + | |
- | echo "le fichier existe !" | + | |
- | else | + | |
- | echo "fichier inexistant: le fichier existe mais dans un script il faut le chemin absolu du fichier testé !" | + | |
- | fi | + | |
- | var1="home/hypathie/toto" | + | Sans espace entre les opérande et la primitive "GNU Linux"=="LINUX" est compris comme une chaîne de caractère.\\ |
- | if [ -f "$var1" ] | + | N'étant pas nulle, le test n'échoue pas. |
- | then | + | |
- | echo "le fichier existe !" | + | |
- | else | + | |
- | echo "fichier inexistant !" | + | |
- | fi | + | |
- | echo " " | + | |
- | var2="home/hypathie/toto" | + | |
- | if test -f "$var2" | + | |
- | then | + | |
- | echo "le fichier existe !" | + | |
- | else | + | |
- | echo "fichier inexistant !" | + | |
- | fi | + | |
- | </code> | + | |
- | * remarque 2: | ||
- | **Les tests sur les fichiers dans le terminal avec commande test :** | ||
- | (Soit le fichier ordinaire "toto") | ||
- | |||
- | <code user> | ||
- | test -f /home/hypathie/toto | ||
- | #puis | ||
- | echo $? | ||
- | </code> | ||
- | Retour : | ||
- | <code> | ||
- | 0 | ||
- | </code> | ||
- | **Les tests sur les fichiers dans le terminal avec les crochets :** | ||
- | <code user> | ||
- | [ -f ~/toto ] | ||
- | #puis | ||
- | echo $? | ||
- | </code> | ||
- | retour : | ||
- | <code> | ||
- | 0 | ||
- | </code> | ||
- | Et voilà ! 8-) | ||
- | ===Tuto précédent === | + | =====Tuto précédent ===== |
- | [[atelier:chantier: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 ===== |
- | [[atelier:chantier: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]] |