2014-10-26 12:44:38 +00:00
|
|
|
|
---
|
|
|
|
|
contributors:
|
|
|
|
|
- ["Max Yankov", "https://github.com/golergka"]
|
|
|
|
|
- ["Darren Lin", "https://github.com/CogBear"]
|
|
|
|
|
- ["Alexandre Medeiros", "http://alemedeiros.sdf.org"]
|
|
|
|
|
- ["Denis Arh", "https://github.com/darh"]
|
|
|
|
|
- ["akirahirose", "https://twitter.com/akirahirose"]
|
|
|
|
|
- ["Anton Strömkvist", "http://lutic.org/"]
|
|
|
|
|
- ["Rahil Momin", "https://github.com/iamrahil"]
|
|
|
|
|
- ["Gregrory Kielian", "https://github.com/gskielian"]
|
2014-10-26 20:33:31 +00:00
|
|
|
|
translators:
|
2014-10-26 12:44:38 +00:00
|
|
|
|
- ["Baptiste Fontaine", "http://bfontaine.net"]
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
|
Bash est le nom du shell UNIX, qui était aussi distribué avec le système
|
2021-05-25 11:42:50 +00:00
|
|
|
|
d’exploitation GNU et est le shell par défaut sur Linux et macOS.
|
2014-10-26 12:44:38 +00:00
|
|
|
|
|
|
|
|
|
Presque tous les exemples ci-dessous peuvent être écrits dans un script shell
|
|
|
|
|
ou exécutés directement dans le terminal.
|
|
|
|
|
|
|
|
|
|
[Plus d’informations ici.](http://www.gnu.org/software/bash/manual/bashref.html)
|
|
|
|
|
|
|
|
|
|
```bash
|
|
|
|
|
#!/bin/bash
|
2024-05-20 04:35:43 +00:00
|
|
|
|
# La première ligne du script s’appelle le « shebang », elle indique au système
|
2014-10-26 12:44:38 +00:00
|
|
|
|
# comment exécuter le script : http://fr.wikipedia.org/wiki/Shebang
|
2024-05-20 04:35:43 +00:00
|
|
|
|
# Comme vous pouvez le remarquer, les commentaires commencent par un « # ».
|
|
|
|
|
# Le shebang est donc aussi un commentaire
|
2014-10-26 12:44:38 +00:00
|
|
|
|
|
|
|
|
|
# Un exemple simple qui affiche « Hello world! » :
|
|
|
|
|
echo Hello world!
|
|
|
|
|
|
|
|
|
|
# Chaque commande commence sur une nouvelle ligne ou après un point-virgule :
|
|
|
|
|
echo 'Ceci est la première ligne'; echo 'Ceci est la seconde ligne'
|
|
|
|
|
|
|
|
|
|
# La déclaration d’une variable ressemble à ça :
|
|
|
|
|
VARIABLE="Du texte"
|
|
|
|
|
|
|
|
|
|
# Mais pas comme ça :
|
2024-05-20 04:35:43 +00:00
|
|
|
|
VARIABLE = "Du texte" # => renvoie une erreur : "Variable: command not found"
|
2014-10-26 12:44:38 +00:00
|
|
|
|
# Bash va penser que VARIABLE est une commande qu’il doit exécuter et va
|
|
|
|
|
# afficher une erreur parce qu’elle est introuvable.
|
|
|
|
|
|
2024-05-20 04:35:43 +00:00
|
|
|
|
# Ni comme ça :
|
|
|
|
|
VARIABLE= 'Some string' # => renvoie une erreur : "Du texte: command not found"
|
|
|
|
|
# Bash va penser que 'Di texte' est une commande qu’il doit exécuter et va
|
|
|
|
|
# afficher une erreur parce qu’elle est introuvable. (Dans ce cas, la partie
|
|
|
|
|
# 'VARIABLE=' est considérée comme une affectation de variable valable uniquement
|
|
|
|
|
# pour la portée de la commande 'Du texte').
|
|
|
|
|
|
2014-11-12 20:40:15 +00:00
|
|
|
|
# Utiliser une variable :
|
2024-05-20 04:35:43 +00:00
|
|
|
|
echo $VARIABLE # => Du texte
|
|
|
|
|
echo "$VARIABLE" # => Du texte
|
|
|
|
|
echo '$VARIABLE' # => $VARIABLE
|
2014-10-26 12:44:38 +00:00
|
|
|
|
# Quand vous utilisez la variable en elle-même – en lui assignant une valeur,
|
|
|
|
|
# en l’exportant ou autre – vous écrivez son nom sans $. Si vous voulez
|
|
|
|
|
# utiliser sa valeur, vous devez utiliser $.
|
2014-11-12 20:40:15 +00:00
|
|
|
|
# Notez qu’entourer une variable de deux guillemets simples (') empêche
|
|
|
|
|
# l’expansion des variables !
|
2014-10-26 12:44:38 +00:00
|
|
|
|
|
2024-05-20 04:35:43 +00:00
|
|
|
|
# Expansion des paramètres (Parameter expansion) ${ } :
|
|
|
|
|
echo ${VARIABLE} # => Du texte
|
|
|
|
|
# Ceci est une utilisation simple de l'expansion de paramètre.
|
|
|
|
|
# L'expansion de paramètre récupère la valeur d'une variable.
|
|
|
|
|
# Elle « déploie » ou imprime la valeur.
|
|
|
|
|
# Lors de l'expansion, la valeur ou le paramètre peut être modifié.
|
|
|
|
|
# Voici d'autres modifications qui s'ajoutent à cette expansion.
|
|
|
|
|
|
2014-11-12 20:40:15 +00:00
|
|
|
|
# Substitution de chaîne de caractères dans une variable
|
2014-10-26 12:44:38 +00:00
|
|
|
|
echo ${VARIABLE/Some/A}
|
2014-11-12 20:40:15 +00:00
|
|
|
|
# Ceci va remplacer la première occurrence de « Some » par « A »
|
2014-10-26 12:44:38 +00:00
|
|
|
|
|
|
|
|
|
# Sous-chaîne d’une variable
|
2024-05-20 04:35:43 +00:00
|
|
|
|
LONGUEUR=5
|
|
|
|
|
echo ${VARIABLE:0:LONGUEUR} # => Du te
|
|
|
|
|
# Ceci va retourner les 5 premiers caractères de la valeur
|
|
|
|
|
echo ${VARIABLE:LONGUEUR} # => xte
|
|
|
|
|
# Ceci va retourner la valeur sans les 5 premiers caractères
|
|
|
|
|
echo ${VARIABLE: -4} # => exte
|
|
|
|
|
# Ceci va retourner les 4 derniers caractères de la valeur
|
|
|
|
|
# (l'espace avant -4 est nécessaire)
|
|
|
|
|
|
|
|
|
|
# Longueur d'une chaîne
|
|
|
|
|
echo ${#VARIABLE} # => 8
|
|
|
|
|
|
|
|
|
|
# Expansion indirecte
|
|
|
|
|
AUTRE_VARIABLE="VARIABLE"
|
|
|
|
|
echo ${!AUTRE_VARIABLE} # => Du texte
|
|
|
|
|
# Cela va utiliser la valeur comme un nom de variable
|
2014-10-26 12:44:38 +00:00
|
|
|
|
|
|
|
|
|
# Valeur par défaut d’une variable
|
2024-05-20 04:35:43 +00:00
|
|
|
|
echo ${FOO:-"ValeurParDefaut"}
|
|
|
|
|
# Retourne 'ValeurParDefaut' si FOO n'a pas été déclarée, si
|
|
|
|
|
# FOO est null (FOO=) ou si FOO est une chaîne vide (FOO="").
|
|
|
|
|
# En revanche Zéro (FOO=0) retourne 0
|
|
|
|
|
|
|
|
|
|
# Les tableaux (array)
|
|
|
|
|
|
|
|
|
|
array0=(un deux trois quatre cinq six)
|
|
|
|
|
# Déclarer un tableau de 6 éléments
|
|
|
|
|
|
|
|
|
|
echo $array0 # => "un"
|
|
|
|
|
# Affiche le premier élément
|
|
|
|
|
|
|
|
|
|
echo ${array0[0]} # => "un"
|
|
|
|
|
# Affiche le premier élément
|
|
|
|
|
|
|
|
|
|
echo ${array0[@]} # => "un deux trois quatre cinq six"
|
|
|
|
|
# Affiche tous les éléments
|
|
|
|
|
|
|
|
|
|
echo ${#array0[@]} # => "6"
|
|
|
|
|
# Attiche le nombre d'éléments
|
|
|
|
|
|
|
|
|
|
echo ${#array0[2]} # => "5"
|
|
|
|
|
# Affiche le nombre de caractères du troisième élément
|
|
|
|
|
|
|
|
|
|
echo ${array0[@]:3:2} # => "quatre cinq"
|
|
|
|
|
# Affiche 2 element en à partir du quatrième
|
|
|
|
|
|
|
|
|
|
for i in "${array0[@]}"; do
|
|
|
|
|
echo "$i"
|
|
|
|
|
done
|
|
|
|
|
# Affiche tous éléments, chacun sur un nouvelle ligne
|
|
|
|
|
|
|
|
|
|
# Brace Expansion { }
|
|
|
|
|
# Permet de générer des tableau
|
|
|
|
|
echo {1..12} # => 1 2 3 4 5 6 7 8 9 10 11 12
|
|
|
|
|
echo {100..95} # => 100 99 98 97 96 95
|
|
|
|
|
echo {a..z} # => a b c d e f g h i j k l m n o p q r s t u v w x y z
|
2014-10-26 12:44:38 +00:00
|
|
|
|
|
|
|
|
|
# Variables pré-remplies :
|
|
|
|
|
# Il y a quelques variables pré-remplies utiles, comme :
|
|
|
|
|
echo "La valeur de retour du dernier programme : $?"
|
|
|
|
|
echo "Le PID du script : $$"
|
|
|
|
|
echo "Nombre d’arguments : $#"
|
|
|
|
|
echo "Arguments du script : $@"
|
|
|
|
|
echo "Arguments du script séparés en plusieurs variables : $1 $2..."
|
|
|
|
|
|
2024-05-20 04:35:43 +00:00
|
|
|
|
# Maintenant que nous savons comment utiliser et afficher des variables,
|
|
|
|
|
# apprenons d'autres fonctionnalités basiques de bash !
|
|
|
|
|
|
|
|
|
|
# Notre répertoire courant est accessible par la commande `pwd`.
|
|
|
|
|
# `pwd` signifie « imprimer le répertoire de travail ».
|
|
|
|
|
# On peut aussi utiliser la variable intégrée `$PWD`.
|
|
|
|
|
# Observez que les commandes suivantes sont équivalentes :
|
|
|
|
|
echo "Je suis dans $(pwd)" # exécute `pwd` et interpole la sortie
|
|
|
|
|
echo "Je suis dans $PWD" # interprète la variable
|
|
|
|
|
|
|
|
|
|
# Si vous avez trop de données dans votre terminal, la commande
|
|
|
|
|
# `clear` efface votre écran
|
|
|
|
|
clear
|
|
|
|
|
# Ctrl-L fonctionne aussi pour effacer la sortie.
|
|
|
|
|
|
2014-10-26 12:44:38 +00:00
|
|
|
|
# Lire une valeur depuis l’entrée standard :
|
|
|
|
|
echo "Quel est votre nom ?"
|
2014-11-12 20:40:15 +00:00
|
|
|
|
read NAME # Notez que l’on n’a pas eu à déclarer une nouvelle variable
|
2014-10-26 12:44:38 +00:00
|
|
|
|
echo Bonjour, $NAME!
|
|
|
|
|
|
|
|
|
|
# Nous avons l’habituelle structure « if » :
|
|
|
|
|
# Utilisez 'man test' pour plus d’informations à propos des conditions
|
2024-05-20 04:35:43 +00:00
|
|
|
|
if [ $NAME != $USER ] # remarque : $USER est le nom l'utilisateur en cours.
|
2014-10-26 12:44:38 +00:00
|
|
|
|
then
|
|
|
|
|
echo "Votre nom n’est pas votre pseudo"
|
|
|
|
|
else
|
|
|
|
|
echo "Votre nom est votre pseudo"
|
|
|
|
|
fi
|
|
|
|
|
|
2024-05-20 04:35:43 +00:00
|
|
|
|
# Remarque : si $NAME est vide, bash verra la condition précédente comme :
|
|
|
|
|
if [ != $USER ]
|
|
|
|
|
# ce qui est syntaxiquement invalide
|
|
|
|
|
# la bonne façon d'utiliser une variable potentiellement vide en bash est :
|
|
|
|
|
if [ "$NAME" != $USER ]
|
|
|
|
|
# ce qui sera interprété par bash si $NAME est vide comme :
|
|
|
|
|
if [ "" != $USER ]
|
|
|
|
|
|
2014-10-26 12:44:38 +00:00
|
|
|
|
# Il y a aussi l’exécution conditionnelle
|
|
|
|
|
echo "Toujours exécuté" || echo "Exécuté si la première commande ne réussit pas"
|
2024-05-20 04:35:43 +00:00
|
|
|
|
# Toujours exécuté
|
2014-10-26 12:44:38 +00:00
|
|
|
|
echo "Toujours exécuté" && echo "Exécuté si la première commande réussit"
|
2024-05-20 04:35:43 +00:00
|
|
|
|
# Toujours exécuté
|
|
|
|
|
# Exécuté si la première commande réussit
|
2014-10-26 12:44:38 +00:00
|
|
|
|
|
|
|
|
|
# Pour utiliser && et || avec des commandes « if, » vous devez utiliser
|
|
|
|
|
# plusieurs paires de crochets :
|
|
|
|
|
if [ $NAME == "Steve" ] && [ $AGE -eq 15 ]
|
|
|
|
|
then
|
|
|
|
|
echo "Ceci sera exécuté si $NAME est Steve ET $AGE est 15."
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
if [ $NAME == "Daniya" ] || [ $NAME == "Zach" ]
|
|
|
|
|
then
|
|
|
|
|
echo "Ceci sera exécuté si $NAME est Daniya OU Zach."
|
|
|
|
|
fi
|
|
|
|
|
|
|
|
|
|
# Les expressions sont écrites dans le format suivant :
|
|
|
|
|
echo $(( 10 + 5 ))
|
|
|
|
|
|
|
|
|
|
# Contrairement aux autres langages de programmation, Bash est un shell — il
|
|
|
|
|
# est donc exécuté dans le contexte du répertoire courant. Vous pouvez lister
|
|
|
|
|
# les fichiers et dossiers dans le répertoire courant avec la commande `ls` :
|
|
|
|
|
ls
|
|
|
|
|
|
|
|
|
|
# Ces commandes ont des options qui contrôlent leur exécution :
|
|
|
|
|
ls -l # Liste tous les fichiers et répertoires sur des lignes séparées
|
|
|
|
|
|
|
|
|
|
# Les résultat de la commande précédente peuvent être passés à la commande
|
|
|
|
|
# suivante en entrée.
|
|
|
|
|
# La commande grep filtre l’entrée avec les motifs donnés. On peut ainsi lister
|
|
|
|
|
# les fichiers .txt dans le répertoire courant :
|
|
|
|
|
ls -l | grep "\.txt"
|
|
|
|
|
|
|
|
|
|
# Vous pouvez aussi rediriger l’entrée et les sorties standards et d’erreur
|
|
|
|
|
# d’une commande :
|
|
|
|
|
python2 hello.py < "entrée.in"
|
|
|
|
|
python2 hello.py > "sortie.out"
|
|
|
|
|
python2 hello.py 2> "erreur.err"
|
|
|
|
|
# Ceci va écraser le fichier s'il existe; si vous préférez écrire à la fin de
|
2014-11-12 20:40:15 +00:00
|
|
|
|
# celui-ci, utilisez >> à la place.
|
2014-10-26 12:44:38 +00:00
|
|
|
|
|
|
|
|
|
# Les commandes peuvent se substituer à l’intérieur d’autres commandes en
|
|
|
|
|
# utilisant $( ) :
|
|
|
|
|
# La commande ci-dessous affiche le nombre de fichiers et répertoires dans le
|
|
|
|
|
# répertoire courant :
|
|
|
|
|
echo "Il y a $(ls | wc -l) choses ici."
|
|
|
|
|
|
|
|
|
|
# On peut faire la même chose avec les accents graves `` mais on ne peut pas
|
|
|
|
|
# les imbriquer — la façon la plus courante est d’utiliser $( ).
|
|
|
|
|
echo "There are `ls | wc -l` items here."
|
|
|
|
|
|
|
|
|
|
# Bash a une commande case qui marche de façon similaire au switch de Java et
|
|
|
|
|
# C++ :
|
|
|
|
|
case "$VARIABLE" in
|
|
|
|
|
#List patterns for the conditions you want to meet
|
|
|
|
|
0) echo "There is a zero.";;
|
|
|
|
|
1) echo "There is a one.";;
|
|
|
|
|
*) echo "It is not null.";;
|
|
|
|
|
esac
|
|
|
|
|
|
|
|
|
|
# La boucle for itère autant de fois qu’elle a d’arguments :
|
|
|
|
|
# Le contenu de $VARIABLE est affiché trois fois.
|
|
|
|
|
for VARIABLE in {1..3}
|
|
|
|
|
do
|
|
|
|
|
echo "$VARIABLE"
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
# Ou écrivez-la de façon « traditionnelle » :
|
|
|
|
|
for ((a=1; a <= 3; a++))
|
|
|
|
|
do
|
|
|
|
|
echo $a
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
# Elles peuvent aussi être utilisées pour agir sur des fichiers :
|
|
|
|
|
# Cette boucle va exécuter la commande 'cat' sur fichier1 et fichier2
|
|
|
|
|
for VARIABLE in fichier1 fichier2
|
|
|
|
|
do
|
|
|
|
|
cat "$VARIABLE"
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
# …ou la sortie d’une commande :
|
|
|
|
|
# Ceci va afficher la sortie de ls.
|
|
|
|
|
for OUTPUT in $(ls)
|
|
|
|
|
do
|
|
|
|
|
cat "$OUTPUT"
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
# Boucle while :
|
|
|
|
|
while [ true ]
|
|
|
|
|
do
|
|
|
|
|
echo "corps de la boucle ..."
|
|
|
|
|
break
|
|
|
|
|
done
|
|
|
|
|
|
|
|
|
|
# Vous pouvez aussi définir des fonctions
|
|
|
|
|
# Définition :
|
|
|
|
|
function foo ()
|
|
|
|
|
{
|
|
|
|
|
echo "Les arguments fonctionnent comme les arguments de script : $@"
|
|
|
|
|
echo "Et : $1 $2..."
|
|
|
|
|
echo "Ceci est une fonction"
|
|
|
|
|
return 0
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Ou plus simplement :
|
|
|
|
|
bar ()
|
|
|
|
|
{
|
|
|
|
|
echo "Une autre façon de définir des fonctions !"
|
|
|
|
|
return 0
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
# Appeler votre fonction
|
|
|
|
|
foo "Mon nom est" $NAME
|
|
|
|
|
|
|
|
|
|
# Il y a plein de commandes utiles que vous devriez apprendre :
|
|
|
|
|
# affiche les 10 dernières lignes de fichier.txt
|
|
|
|
|
tail -n 10 fichier.txt
|
|
|
|
|
# affiche les 10 premières lignes de fichier.txt
|
|
|
|
|
head -n 10 fichier.txt
|
|
|
|
|
# trie les lignes de fichier.txt
|
|
|
|
|
sort fichier.txt
|
|
|
|
|
# montre ou omet les lignes répétées, avec -d pour les montrer
|
|
|
|
|
uniq -d fichier.txt
|
|
|
|
|
# affiche uniquement la première colonne avant le caractère « , »
|
|
|
|
|
cut -d ',' -f 1 fichier.txt
|
|
|
|
|
# remplace chaque occurrence de 'okay' par 'super' dans fichier.txt
|
|
|
|
|
# (compatible avec les expression rationnelles)
|
|
|
|
|
sed -i 's/okay/super/g' fichier.txt
|
|
|
|
|
# affiche toutes les lignes de fichier.txt qui correspondent à une expression
|
|
|
|
|
# rationnelle, dans cet exemple les lignes qui commencent par « foo » et
|
|
|
|
|
# finissent par « bar »
|
|
|
|
|
grep "^foo.*bar$" fichier.txt
|
|
|
|
|
# ajoutez l’option « -c » pour afficher le nombre de lignes concernées
|
|
|
|
|
grep -c "^foo.*bar$" fichier.txt
|
|
|
|
|
# Si vous voulez vraiment chercher une chaîne de caractères, et non
|
|
|
|
|
# l’expression rationnelle, utilisez fgrep (ou grep -F)
|
|
|
|
|
fgrep "^foo.*bar$" fichier.txt
|
|
|
|
|
```
|