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:script-bash-variables-arguments-parametres [07/07/2014 16:50] Hypathie [Création, suppression, exportation de variables] |
doc:programmation:shells:script-bash-variables-arguments-parametres [07/07/2014 17:26] Hypathie [Création, suppression, exportation de variables] |
||
---|---|---|---|
Ligne 147: | Ligne 147: | ||
</code> | </code> | ||
- | On entre par exemple debian facile, puis on peut récupérer la valeur de chacune des variables "nom" et "prenom" | + | >On entre par exemple debian facile, puis on peut récupérer la valeur de chacune des |
+ | >variables "nom" et "prenom". | ||
<code user> | <code user> | ||
Ligne 158: | Ligne 159: | ||
Mais dans un script c'est plus rapide ! 8-) | Mais dans un script c'est plus rapide ! 8-) | ||
- | * Remarque : | + | >Ci-dessous, on ne met pas le "nom" de la variable, parce qu'on ne cherche pas |
- | Ci-dessous, on ne met pas le "nom" de la variable, parce qu'on ne cherche pas à appeler la valeur de cette variable mais à permettre au programme de se poursuivre.\\ | + | >à appeler >la valeur de cette variable mais à permettre au programme de se poursuivre. |
- | Quand on entre dans le terminal la réponse attendu par "read", le retour de la commande et zéro, donc elle est considérée comme exécutée, et le shell passe à l'exécution de la commande suivante. | + | >Quand on entre dans le terminal la réponse attendu par "read", le retour de la |
+ | >commande est zéro, donc elle est considérée comme exécutée, et le shell passe à | ||
+ | >l'exécution de la commande suivante. | ||
<code bash> | <code bash> | ||
Ligne 169: | Ligne 172: | ||
<note> | <note> | ||
- | **Les options de read les plus intéressantes.** | + | Les options de read les plus intéressantes. |
* -p : afficher un message | * -p : afficher un message | ||
* -n : limiter le nombre de caractères | * -n : limiter le nombre de caractères | ||
* -t : limiter le temps autorisé pour saisir un message | * -t : limiter le temps autorisé pour saisir un message | ||
* -s : ne pas afficher le texte saisi | * -s : ne pas afficher le texte saisi | ||
- | par exemple: | + | On peut utiliser plusieurs options. Par exemple: |
- | read -p "entrez votre de naissance (deux derniers chiffres): " -n 2 annee | + | <code user> |
+ | read -p "entrez votre année de naissance (deux derniers chiffres): " -n 2 annee | ||
+ | </code> | ||
</note> | </note> | ||
- | ====3) Modification de la valeur d'une variable et protection ==== | + | ====Modification de la valeur d'une variable ==== |
- | + | ||
- | ===Modification=== | + | |
Pour modifier la valeur d'une variable, il suffit de l'affecter d'une nouvelle valeur. | Pour modifier la valeur d'une variable, il suffit de l'affecter d'une nouvelle valeur. | ||
Ligne 202: | Ligne 205: | ||
</code> | </code> | ||
- | ===protection : "readonly" === | + | ====Protection de variable : "readonly" ==== |
On protège une variable avec la commande "readonly". La variable devient alors "une variable en lecture seule". Cela lui donne la caractéristique d'être figée : on ne peut plus alors, au cours du même script, réaffectée par une nouvelle valeur une même variable, y compris si cette variable a été déclarée vide. | On protège une variable avec la commande "readonly". La variable devient alors "une variable en lecture seule". Cela lui donne la caractéristique d'être figée : on ne peut plus alors, au cours du même script, réaffectée par une nouvelle valeur une même variable, y compris si cette variable a été déclarée vide. | ||
Ligne 274: | Ligne 277: | ||
==== Exportation de la valeur d'une variable==== | ==== Exportation de la valeur d'une variable==== | ||
- | + | === Définition === | |
- | Exporter la valeur d'une variable signifie que l'on envoie à un processus fils, la valeur d'une variable d'un processus père. | + | Exporter la valeur d'une variable signifie que l'on envoie à un processus fils, la valeur d'une variable depuis un processus père. |
<note> | <note> | ||
Un processus, c'est un programme en cours d'exécution, mais aussi son environnement d'exécution.\\ | Un processus, c'est un programme en cours d'exécution, mais aussi son environnement d'exécution.\\ | ||
Ainsi le shell qui lance un script est le processus père du script lancé. | Ainsi le shell qui lance un script est le processus père du script lancé. | ||
+ | Sur la notion de processus voir [[atelier:chantier:bash-les-differents-caracteres-speciaux?&#notion-de-processus|Notion de processus]] | ||
</note> | </note> | ||
- | * On peut exporter depuis le terminal, une valeur pour remplacer provisoirement une variable d'un script. | + | === Exemple === |
+ | On peut exporter depuis le terminal, une valeur pour remplacer provisoirement une variable d'un script. | ||
<code user> | <code user> | ||
Coucou="Bonjour" | Coucou="Bonjour" | ||
Ligne 311: | Ligne 316: | ||
>Mais une fois le terminal réinitialisé, si on lance ./test.sh, ce script est le | >Mais une fois le terminal réinitialisé, si on lance ./test.sh, ce script est le | ||
>processus fils de ce "nouveau" processus père (= le nouveau terminal) qui n'a plus | >processus fils de ce "nouveau" processus père (= le nouveau terminal) qui n'a plus | ||
- | > en mémoire la valeur "Bonjour" pour la variable vide "Coucou". | + | > en mémoire la valeur "Bonjour" pour la variable nulle "Coucou" du script. |
>Et dans ce cas : | >Et dans ce cas : | ||
<code user> | <code user> | ||
Ligne 334: | Ligne 339: | ||
. ~/.bashrc | . ~/.bashrc | ||
</code> | </code> | ||
- | |||
</note> | </note> | ||
=====Quand les valeurs sont des paramètres ===== | =====Quand les valeurs sont des paramètres ===== |