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 [30/05/2014 07:55] Hypathie [Opérateurs lexicographiques] |
doc:programmation:shells:la-page-man-bash-ii-les-operateurs-lexicographiques [16/02/2023 22:32] agp91 [Introduction] |
||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
+ | |||
======Bash : les opérateurs lexicographiques ====== | ======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. | * Objet : suite de la série de wiki visant à maîtriser bash via les différents caractère spéciaux. | ||
- | * Niveau requis : {{tag>débutant}} | + | * Niveau requis : {{tag>débutant avisé}} |
* 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 : |
- | * 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 !)) | + | |
- | **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]] | ||
+ | * ;-) | ||
+ | * [[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 !\\ | + | 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>**. | ||
- | 4) chap IV : [[atelier:chantier:page-man-bash-iii-les-operateurs-de-comparaison-numerique|Bash : les opérateurs de comparaison numérique]]\\ | + | 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. | ||
- | 5) chap V : [[atelier:chantier:page-man-bash-iv-symboles-dans-les-calculs-mathematiques|Bash : les symboles dans les calculs]]\\ | + | __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. | ||
- | 6) chap VI : [[atelier:chantier:page-man-bash-v-les-tableaux|Bash : les tableaux]]\\ | ||
- | 7) chap VII : [[atelier:chantier:man-bash-vi-les-caracteres-de-transformation-de-parametres|Bash : les caractères de transformation de parametres]]\\ | + | ===== Opérateurs sur chaîne(s) ===== |
- | 8) chap VIII : [[atelier:chantier:bash-vii-globs-etendus-regex|Bash : globs étendus et regex]] | + | ==== Test sur 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 : |
+ | <code> | ||
+ | test OP chaîne | ||
+ | [ OP chaîne ] | ||
+ | [[ OP chaîne ]] | ||
- | ====1) Caractères de comparaison sur les chaînes de caractères ==== | + | Chaîne est sujette au développement des paramètres. |
- | *Le shell bash utilise les opérateurs booléens sur les chaînes de caractère : == , != , < , > , >=, <= , | + | Avec pour OP, l'un des opérateur du tableau suivant. |
- | *contexte : conditions (voir man bash lignes 2498-2513 | + | </code> |
- | ^ Condition ^ Signification ^ | + | Si l'opérande contient des espaces, il doit être protégé |
- | |$chaine1 = $chaine2 | est égal | | + | | Opérateurs de test sur chaîne || |
- | |$chaîne1 == $chaîne2 | synonyme de = | | + | ^ Opérateurs ^ Signification ^ |
- | |$chaine1 != $chaine2 | n'est pas égal à | | + | |''-z'' | Chaîne de longueur nulle | |
- | |$chaine1 < $chaîne2 | avant (selon l'ordre alphabétique ASCII) | | + | |''-n'' | Chaîne de longueur non nulle | |
- | |$chaine1 < $chaîne2 | après (ASCII) | | + | |
- | *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 : | + | <code user> |
+ | test -z ; echo $? #Test si vide et affiche le code retour | ||
+ | [ -n "" ] ; echo $? #Test si non vide et affiche le code retour | ||
+ | [[ -z "" ]] ; echo $? #Test si vide et affiche le code retour | ||
+ | </code> | ||
+ | <file config Retour des commandes> | ||
+ | 0 | ||
+ | 1 | ||
+ | 0 | ||
+ | </file> | ||
+ | |||
+ | <code user> | ||
+ | test -z "mot" ; echo $? | ||
+ | [ -n "Linux" ] ; echo $? | ||
+ | [[ -z "GNU Linux" ]] ; echo $? | ||
+ | </code> | ||
+ | <file config Retour des commandes> | ||
+ | 1 | ||
+ | 0 | ||
+ | 1 | ||
+ | </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 $? | ||
+ | |||
+ | </code> | ||
+ | <file config Retour des commandes> | ||
+ | 1 | ||
+ | 0 | ||
+ | 0 | ||
+ | </file> | ||
+ | |||
+ | ==== Mauvais usages ==== | ||
+ | |||
+ | 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. | ||
<code> | <code> | ||
- | Le shell bash utilise les commandes internes et composées [[ ]] ou [ ] | + | p="Debian Facile" |
- | (souvent utilisées avec IF) pour les comparaisons de chaînes de caractères. | + | test -z $p ; echo $? |
+ | |||
+ | unset p | ||
</code> | </code> | ||
+ | <file config Retour des commandes> | ||
+ | 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> | ||
+ | |||
+ | Avec la commande **[** ou **test**, l'opérateur **-n** revoie un code de retour inattendu, quand un paramètre vide est testé sans protection. | ||
+ | <code> | ||
+ | test -n $p ; echo $? | ||
+ | [ -n $p ] ; echo $? | ||
+ | |||
+ | p="" | ||
+ | [[ -n $p ]] ; echo $? | ||
+ | |||
+ | unset p | ||
+ | </code> | ||
+ | <file> | ||
+ | 0 | ||
+ | 0 | ||
+ | 1 | ||
+ | </file> | ||
+ | |||
+ | ==== Bon usage ==== | ||
+ | |||
+ | 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 **+**.\\ | ||
+ | (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> | ||
+ | p="Debian GNU Linux" | ||
+ | |||
+ | test -z ${p+x} ; echo $? | ||
+ | [ -z ${p+x} ] ; echo $? | ||
+ | [[ -z ${p+x} ]] ; echo $? | ||
+ | |||
+ | unset p | ||
+ | </code> | ||
+ | <file config Retour de la commande> | ||
+ | 1 | ||
+ | 1 | ||
+ | 1 | ||
+ | </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 ===== | ||
+ | |||
+ | 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 -a 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 | | ||
- | *remarques : | + | <note important> |
__-bashismes :__ | __-bashismes :__ | ||
<code> | <code> | ||
[[ $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> | ||
__ | __ | ||
Ligne 63: | Ligne 188: | ||
<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 ==== |
- | Rappel:\\ | + | * Dans le terminal, crochets ou commande test: |
- | Les opérateurs de comparaison (crochets) relève d'un mécanisme interne au shell.\\ | + | <code user> |
- | La commande test permet elle aussi de faire des tests.\\ | + | test1= |
- | Elle s'utilise avec les mêmes expressions de comparaison mais avec cette syntaxe :\\ | + | #puis |
+ | [ -n "$test1" ] | ||
+ | #puis | ||
+ | echo $? | ||
+ | </code> | ||
+ | <file config retour de la commande> | ||
+ | 1 | ||
+ | </file> | ||
- | <code> | + | >Donc la chaîne de la variable test1 est égale à zéro. |
- | test expression ou bien [ expression ] | + | |
- | $ test -f /etc/gaga $ [ -f /etc/gaga ] | + | * Autre exemple : |
- | $ echo $? $ echo $? | + | |
- | 1 1 | + | <code user> |
- | $ $ | + | test2=abc |
+ | #puis | ||
+ | test3=ab | ||
+ | #puis | ||
+ | [ "$test2" = "$test3" ] | ||
+ | #puis | ||
+ | echo $? | ||
</code> | </code> | ||
- | Dans les deux cas, le fichier /etc/gaga n'existe pas.\\ | + | <file config retour de la commande> |
- | (Si le fichier /etc/gaga existait, le retour serait 0.) | + | 1 |
- | </note> | + | </file> |
- | ====2) Caractères de comparaison de fichiers==== | + | >Donc les deux chaînes de valeur contenue dans les variables test2 et test3 ne sont pas égales. |
- | *Le shell bash | + | |
- | <code> | + | * Dans les scripts, c'est pareil ! ;-) |
- | Il permet d'effectuer aussi des comparaisons sur les fichiers avec | + | Tests avec les crochets : |
- | les commandes internes et composées [[ ]] et [ ]] | + | |
- | (associées à IF ou non). | + | <code bash mon-script> |
- | Les commandes [[ ]] et [ ] suppléent la commande test. | + | #!/bin/bash |
- | Pour les comparaisons de nombres, on peut utiliser aussi la commande test. | + | var1="def" |
+ | var2="def" | ||
+ | if [ $var1 == $var2 ] ; then | ||
+ | echo "1)test de correspondance chaîne de caractères sur valeur de variable: \$var1:"$var1" correspond(==) à \$var2:"$var2"." | ||
+ | fi | ||
+ | |||
+ | var3="hip" | ||
+ | var4="hip" | ||
+ | if test $var3 = $var4 ; then | ||
+ | echo "2) test de correspondance chaîne de caractères sur valeur de variable: \$var3:"$var3" correspond(=) à \$var4:"$var4"." | ||
+ | fi | ||
+ | </code> | ||
+ | |||
+ | <code user> | ||
+ | ./mon-script | ||
</code> | </code> | ||
- | <code> | + | <file config retour de la commande> |
+ | 1) test de correspondance chaîne de caractères sur valeur de variable: $var1:def correspond(==) à $var2:def. | ||
+ | 2) test de correspondance chaîne de caractères sur valeur de variable: $var3:hip correspond(=) à $var4:hip. | ||
+ | </file> | ||
+ | |||
+ | Tests avec la commande test : | ||
+ | |||
+ | <code user> | ||
+ | test4=tout-compris | ||
+ | #puis | ||
+ | test5=toutcompris | ||
+ | #puis | ||
+ | test $test4 = $test5 | ||
+ | #puis | ||
+ | echo $? | ||
+ | </code> | ||
+ | |||
+ | <file config retour de la commande> | ||
+ | 1 | ||
+ | </file> | ||
+ | |||
+ | >Donc les chaînes des deux valeurs sont différentes. | ||
+ | |||
+ | <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 booléens de comparaison numérique]] qui utilisent les mêmes symboles (mais avec la syntaxe doubles parenthèses et surtout pas de crochets).\\ | ||
+ | </note> | ||
+ | |||
+ | <code bash script> | ||
+ | #!/bin/bash | ||
+ | a="sloiuy" | ||
+ | b="aktgjaùkjayaj" | ||
+ | if [[ $a < $b ]] ; then | ||
+ | echo "OK l'opérateur < fonctionne avec les chaînes de caractère" | ||
+ | fi | ||
+ | echo " " | ||
+ | if [[ $a > $b ]] ; then | ||
+ | echo "Les opérateurs < et > signifient avant et après selon l'ordre alphabétique (doubles crochets) " | ||
+ | fi | ||
+ | echo " " | ||
+ | if [ $a \> $b ] ; then | ||
+ | echo "Les opérateurs \< et \> signifient avant et après selon l'ordre alphabétique (simples crochets) " | ||
+ | fi | ||
+ | </code> | ||
+ | <code user>./mon_script</code> | ||
+ | <file config retour de la commande> | ||
+ | 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 (simples crochets) | ||
+ | </file> | ||
+ | |||
+ | |||
+ | ===== 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 ]] | if [[ option $FICHIER ]] | ||
</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.| | ||
- | ^ 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) | | + | |
- | Exemple : | + | ==== Test dans un script ==== |
- | <code> | + | Soit le script mon_script. |
+ | <code bash script> | ||
#!/bin/bash | #!/bin/bash | ||
- | var="/home/hypathie/Dossier/fichierp1" | + | var1="~/toto" |
- | if [ -e "$var" ] | + | if [ -f "$var1" ] |
then | then | ||
echo "le fichier existe !" | echo "le fichier existe !" | ||
else | else | ||
- | echo "fichier inexistant !" | + | 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 | ||
- | var2="/home/hypathie/Dossier/fichierp1" | + | |
- | if [ -s "$var2" ] | + | var1="home/hypathie/toto" |
+ | if [ -f "$var1" ] | ||
then | then | ||
- | echo "non vide !" | + | echo "le fichier existe !" |
else | else | ||
- | echo "vide !" | + | echo "fichier inexistant !" |
+ | fi | ||
+ | if test -f "$var1" | ||
+ | then | ||
+ | echo "le fichier existe !" | ||
+ | else | ||
+ | echo "fichier inexistant !" | ||
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> | ||
+ | |||
+ | ==== 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 ===== |
- | [[atelier:chantier: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 ===== |
- | [[atelier:chantier: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]] |