|
| 1 | +# Les Expressions Conditionnelles en Bash |
| 2 | + |
| 3 | +En informatique, les affirmations conditionnelles, expressions conditionnelles et constructions conditionnelles sont des fonctionnalités d'un langage de programmation qui effectuent des opérations différentes en fonction de la valeur booléenne d'une condition spécifiée par le développeur, `true` (vrai) ou `false` (faux). |
| 4 | + |
| 5 | +En Bash, les expressions conditionnelles utilisent les commandes `[[` et `[` pour tester les attributs d'un fichier et effectuer des comparaisons arithmétiques ou à partir de strings. |
| 6 | + |
| 7 | +Voici une liste des expressions conditionnelles Bash les plus populaires. Vous n'avez pas besoin de les retenir par coeur. Vous pouvez simplement vous référer à cette liste quand vous en avez besoin ! |
| 8 | + |
| 9 | +## Expressions à partir d'un fichier |
| 10 | + |
| 11 | +* Vrai si le fichier existe. |
| 12 | + |
| 13 | +```bash |
| 14 | +[[ -a ${fichier} ]] |
| 15 | +``` |
| 16 | + |
| 17 | +* Vrai si le fichier existe et est un fichier spécial en mode bloc (block special file). |
| 18 | + |
| 19 | +```bash |
| 20 | +[[ -b ${fichier} ]] |
| 21 | +``` |
| 22 | + |
| 23 | +* Vrai si le fichier existe et est un fichier spécial en mode caractère (character special file). |
| 24 | + |
| 25 | +```bash |
| 26 | +[[ -c ${fichier} ]] |
| 27 | +``` |
| 28 | + |
| 29 | +* Vrai si le fichier existe et est un dossier. |
| 30 | + |
| 31 | +```bash |
| 32 | +[[ -d ${fichier} ]] |
| 33 | +``` |
| 34 | + |
| 35 | +* Vrai si le fichier existe. |
| 36 | + |
| 37 | +```bash |
| 38 | +[[ -e ${fichier} ]] |
| 39 | +``` |
| 40 | + |
| 41 | +* Vrai si le fichier existe et est un fichier normal. |
| 42 | + |
| 43 | +```bash |
| 44 | +[[ -f ${fichier} ]] |
| 45 | +``` |
| 46 | + |
| 47 | +* Vrai si le fichier existe et est un lien symbolique. |
| 48 | + |
| 49 | +```bash |
| 50 | +[[ -h ${fichier} ]] |
| 51 | +``` |
| 52 | + |
| 53 | +* Vrai si le fichier existe et est lisible. |
| 54 | + |
| 55 | +```bash |
| 56 | +[[ -r ${fichier} ]] |
| 57 | +``` |
| 58 | + |
| 59 | +* Vrai si le fichier existe et a une taille supérieure à zéro. |
| 60 | + |
| 61 | +```bash |
| 62 | +[[ -s ${fichier} ]] |
| 63 | +``` |
| 64 | + |
| 65 | +* Vrai si le fichier existe et peut recevoir des écritures. |
| 66 | + |
| 67 | +```bash |
| 68 | +[[ -w ${fichier} ]] |
| 69 | +``` |
| 70 | + |
| 71 | +* Vrai si le fichier existe et est exécutable. |
| 72 | + |
| 73 | +```bash |
| 74 | +[[ -x ${fichier} ]] |
| 75 | +``` |
| 76 | + |
| 77 | +* Vrai si le fichier existe et est un lien symbolique. |
| 78 | + |
| 79 | +```bash |
| 80 | +[[ -L ${fichier} ]] |
| 81 | +``` |
| 82 | + |
| 83 | +## Les expressions sur des strings |
| 84 | + |
| 85 | +* Vrai si la variable varname existe (on lui a assigné une valeur). |
| 86 | + |
| 87 | +```bash |
| 88 | +[[ -v ${varname} ]] |
| 89 | +``` |
| 90 | + |
| 91 | +* Vrai si la string a une longueur égale à 0. |
| 92 | + |
| 93 | +```bash |
| 94 | +[[ -z ${string} ]] |
| 95 | +``` |
| 96 | + |
| 97 | +* Vrai si la string a une longueur différente de 0. |
| 98 | + |
| 99 | +```bash |
| 100 | +[[ -n ${string} ]] |
| 101 | +``` |
| 102 | + |
| 103 | +* Vrai si les strings sont égales. `=` doit être utilisé avec la commande `[` pour être conforme à la norme POSIX. Quand vous utilisez la commande `[[`, vous cherchez des correspondances de motifs entre les deux strings. |
| 104 | + |
| 105 | +```bash |
| 106 | +[[ ${string1} == ${string2} ]] |
| 107 | +``` |
| 108 | + |
| 109 | +* Vrai si les strings sont différentes. |
| 110 | + |
| 111 | +```bash |
| 112 | +[[ ${string1} != ${string2} ]] |
| 113 | +``` |
| 114 | + |
| 115 | +* Vrai si string1 précède string2 alphabétiquement. |
| 116 | + |
| 117 | +```bash |
| 118 | +[[ ${string1} < ${string2} ]] |
| 119 | +``` |
| 120 | + |
| 121 | +* Vrai si string1 suit string2 alphabétiquement. |
| 122 | + |
| 123 | +```bash |
| 124 | +[[ ${string1} > ${string2} ]] |
| 125 | +``` |
| 126 | + |
| 127 | +## Les opérateurs arithmétiques |
| 128 | + |
| 129 | +* Vrai si les nombres sont **égaux**. |
| 130 | + |
| 131 | +```bash |
| 132 | +[[ ${arg1} -eq ${arg2} ]] |
| 133 | +``` |
| 134 | + |
| 135 | +* Vrai si les nombres ne sont **pas égaux**. |
| 136 | + |
| 137 | +```bash |
| 138 | +[[ ${arg1} -ne ${arg2} ]] |
| 139 | +``` |
| 140 | + |
| 141 | +* Vrai si arg1 est **plus petit que** arg2. |
| 142 | + |
| 143 | +```bash |
| 144 | +[[ ${arg1} -lt ${arg2} ]] |
| 145 | +``` |
| 146 | + |
| 147 | +* Vrai si arg1 est **plus petit ou égal à** arg2. |
| 148 | + |
| 149 | +```bash |
| 150 | +[[ ${arg1} -le ${arg2} ]] |
| 151 | +``` |
| 152 | + |
| 153 | +* Vrai si arg1 est **plus grand que** arg2. |
| 154 | + |
| 155 | +```bash |
| 156 | +[[ ${arg1} -gt ${arg2} ]] |
| 157 | +``` |
| 158 | + |
| 159 | +* Vrai si arg1 est **plus grand ou égal à** arg2. |
| 160 | + |
| 161 | +```bash |
| 162 | +[[ ${arg1} -ge ${arg2} ]] |
| 163 | +``` |
| 164 | + |
| 165 | +Pour information, arg1 et arg2 peuvent être des entiers positifs ou négatifs. |
| 166 | + |
| 167 | +Comme avec d'autres langages de programmation, vous pouvez utiliser les conditions `AND` (et) & `OR` (ou) : |
| 168 | + |
| 169 | +```bash |
| 170 | +[[ test_case_1 ]] && [[ test_case_2 ]] # And |
| 171 | +[[ test_case_1 ]] || [[ test_case_2 ]] # Or |
| 172 | +``` |
| 173 | + |
| 174 | +## Opérateurs sur le statut de fin d'une commande |
| 175 | + |
| 176 | +* Vrai si la commande a réussi et n'a pas rencontré d'erreur. |
| 177 | + |
| 178 | +```bash |
| 179 | +[[ $? -eq 0 ]] |
| 180 | +``` |
| 181 | + |
| 182 | +* Vrai si la commande n'a pas réussi ou a rencontré une erreur. |
| 183 | + |
| 184 | +```bash |
| 185 | +[[ $? -gt 0 ]] |
| 186 | +``` |
0 commit comments