logo Debian Debian Debian-France Debian-Facile Debian-fr.org Forum-Debian.fr Debian ? Communautés logo inclusivité

Debian-facile

Bienvenue sur Debian-Facile, site d'aide pour les nouveaux utilisateurs de Debian.

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 → ODT PDF Export

Différences

Ci-dessous, les différences entre deux révisions de la page.

Lien vers cette vue comparative

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 [03/06/2014 16:31]
Hypathie [G ) Déclarer des paramètres de position : set]
doc:programmation:shells:script-bash-variables-arguments-parametres [10/07/2014 13:06]
Hypathie [Variables numériques et calculs]
Ligne 1: Ligne 1:
-======script ​bash : variables, arguments, paramètres ======+======Script ​bash : variables, arguments, paramètres ======
  
-  ​* Objet : suite du wiki "​Apprendre à rédiger des scripts sous bash"​ +  * Niveau requis : {{tag>​débutant}}
-  ​* Niveau requis : {{tag>​débutant }} +
-  * Commentaires : //Contexte d'​utilisation du sujet du tuto. // FIXME+
   * 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 : {{tag>en-chantier à-tester ​à-placer}} ​- FIXME Pour choisir, voir les autres Tags possibles dans [[:​atelier:#​tags|l'​Atelier]]. +  * Suivi : {{tag>​à-placer}} 
-    * Création par **Hypathie** 03/06/2014 +    * Création par [[user>Hypathie]] 18/03/2014 
-    * Testé par <...> le <...FIXME +    * Testé par <Hypathie> le <Juin 2014
-  * Commentaires sur le forum : [[url | Lien vers le forum concernant ce tuto]] ((N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !)) FIXME+  * Commentaires sur le forum : [[https://​debian-facile.org/​viewtopic.php?​pid=92203#​p92203| Lien vers le forum concernant ce tuto]] ((N'​hésitez pas à y faire part de vos remarques, succès, améliorations ou échecs !))
  
-**Nota :**+ 
 +  ​[[atelier:​chantier:​debuter-avec-les-scripts-shell-bash]] 
 +  ​[[atelier:chantier:​script-bash-detail-sur-les-parametres-et-les-boucles|script bash : modification de variable et de paramètre]] 
 +  ​[[atelier:​chantier:​script-bash-enchainement-de-commandes-et-etat-de-sortie|script-bash-enchainement-de-commandes-et-etat-de-sortie]] 
 +  ​[[atelier:​chantier:​script-bash-etat-de-sorie-et-les-tests|script-bash-etat-de-sorie-et-les-tests]] 
 +  * [[atelier:​chantier:​script-bash-les-tableaux|script-bash-les-tableaux]] 
 +  * [[atelier:​chantier:​script-bash-les-fonctions|script-bash-les-fonctions]]
  
 Contributeurs,​ les FIXME sont là pour vous aider, supprimez-les une fois le problème corrigé ou le champ rempli ! Contributeurs,​ les FIXME sont là pour vous aider, supprimez-les une fois le problème corrigé ou le champ rempli !
  
-===== Création de variables ===== +===== Création, suppression,​ exportation ​de variables =====
-En liens nécessaires : \\  +
-[[doc:​programmation:​shell:​shell#​variables-et-environnement|Le shell pour tous : "​Variables et environnement"​]]\\  +
-[[doc:​programmation:​shell:​variables]]+
    
-**Le nom d'une variable est un simple pointeur vers l'​emplacement mémoire où sont conservées les données qu'​elle contient.**\\ +Le nom d'une variable est un simple pointeur vers l'​emplacement mémoire où sont conservées les données qu'​elle contient.\\ ​
  
-**Les variables qu'on crée dans un script (ou dans le terminal) sont localisées dans ce script (ou à l'​ouverture d'un terminal) c'​est-à-dire qu'​elles ne sont utilisables que lorsqu'​on exécute son script, (ou que l'on appelle la valeur d'une variable qu'on vient de déclarer dans un terminal). Et il s'agit du script d'un utilisateur,​ il faut les distinguer [[atelier:​chantier:​la-page-man-bash-les-caracteres-speciaux#​caracteres-des-variables-de-substitution-predefinies|des variables de substitution prédéfinies]] et [[atelier:​chantier:​la-page-man-bash-les-caracteres-speciaux#​appel-de-la-valeur-des-variables-d-environnement-predefinies|des variables d'​environnement prédéfinies]].**+Les variables qu'on crée dans un script (ou dans le terminal) sont localisées dans ce script (ou à l'​ouverture d'un terminal) c'​est-à-dire qu'​elles ne sont utilisables que lorsqu'​on exécute son script, (ou que l'on appelle la valeur d'une variable qu'on vient de déclarer dans un terminal). Et il s'agit du script d'un utilisateur,​ il faut les distinguer [[atelier:​chantier:​la-page-man-bash-les-caracteres-speciaux#​caracteres-des-variables-de-substitution-predefinies|des variables de substitution prédéfinies]] et [[atelier:​chantier:​la-page-man-bash-les-caracteres-speciaux#​appel-de-la-valeur-des-variables-d-environnement-predefinies|des variables d'​environnement prédéfinies]].
  
-**Mais comment enregistrer une valeur en mémoire ?**\\ +Mais comment enregistrer une valeur en mémoire ?\\  
 +  
 +C'est par exemple, l'​affectation d'une valeur au nom d'une variable qui va permettre d'​enregistrer en mémoire cette variable avec sa valeur\\  ​
  
-**Comme vous allez le comprendre, ​une valeur ​est mémorisée ​au moyen de l'un des mécanismes internes du shell et il y en a plusieurs.**\\  +<​note>​ 
-** __C'est par exemple, l'​affectation d'une valeur au nom d'une variable ​qui va permettre d'​enregistrer en mémoire cette variable avec sa valeur__**\\   +Avant tout prenez bien conscience que la déclaration d'une variable n'est pas confinée ​au script, mais qu'il est possible de déclarer ​une variable ​dans le shell courant (dans le terminal). Voir absolument : [[atelier:​chantier:​la-page-man-bash-les-caracteres-speciaux#​details-sur-le-caractere|détail sur le caractère $]]. 
- +</​note>​ 
-Voyons d'​abord comment créer une variable de cette manière et comment utiliser sa valeur. ;-)+**Voyons d'​abord comment créer une variable de cette manière et comment utiliser sa valeur.** ;-)
  
-====1) Affectation directe : ====+==== Affectation directe : ====
    
-  * **La déclaration d'une variable se fait lors de son affectation,​ c'​est-à-dire lorsqu'​on assigne au nom de la variable une valeur au moyen du caractère = (sans espace avant et après).**\\  +La déclaration d'une variable se fait lors de son affectation,​ c'​est-à-dire lorsqu'​on assigne au nom de la variable une valeur au moyen du caractère = (sans espace avant et après). 
-** Avant tout prenez bien conscience que la déclaration d'une variable n'est pas confinée au script, mais qu'il est possible de déclarer une variable dans le shell courant (dans le terminal). Voir absolument : [[atelier:​chantier:​la-page-man-bash-les-caracteres-speciaux#​details-sur-le-caractere|détail sur le caractère $]].** + 
-<​code>​+<​code ​bash>
 #!/bin/bash #!/bin/bash
-NomDelaVariable=ValeurDeLaVariable+nom_de_la_variable=ValeurDeLaVariable
 </​code>​ </​code>​
- => La valeur "​ValeurDeLaVariable"​ a été mémorisée. 
  
-  * **Pour "​utiliser"​ une variable, on se sert de sa valeur : il faut donc appeler sa valeur et cela se fait avec le caractère spécial $ accolé au nom de la variable** :\\ +>La valeur ''​ValeurDeLaVariable''​ a été mémorisée. 
 + 
 +===$nom_de_la_variable=== 
 +Pour "​utiliser"​ une variable, on se sert de sa valeur : il faut donc appeler sa valeur et cela se fait avec le caractère spécial ​''​$'' ​accolé au nom de la variable :
    
 <code bash> <code bash>
Ligne 48: Ligne 53:
 ls -la ~/​$nx_fichier ls -la ~/​$nx_fichier
 </​code>​ </​code>​
 +>Les programmes (ou commandes) ''​touch''​ et ''​ls''​ ont utilisé la valeur de 
 +>la fonction nommée ''​nx_fichier'',​ dont la valeur correspond à la chaîne ​
 +>de caractères ''​les_fonctions''​.
  
-=> Les programmes (ou commandes) "​touch"​ et "​ls"​ ont utilisé la valeur de la fonction nommée "​nx_fichier",​ d'une valeur qui correspond à la chaîne de caractères "​les_fonctions"​. +===Une variable n'est pas typée=== 
- +La valeur d'une variable ​peut être un nombre, un ou plusieurs caractères,​ du texte espacé, ​une commande, la valeur d'une variable.
-  * **Exemple où la valeur d'une variable ​est un nombre, un ou plusieurs caractères,​ du texte espacé, ​ou une variable.**\\+
  
 <code bash> <code bash>
Ligne 63: Ligne 70:
 echo -e "​valeur de var1: $var1\nvaleur de var2: $var2\nvaleur de var3: $var3\nvaleur de var3: $var4\nvaleur de var5: $var5\nvar6:​ $var6" ​             echo -e "​valeur de var1: $var1\nvaleur de var2: $var2\nvaleur de var3: $var3\nvaleur de var3: $var4\nvaleur de var5: $var5\nvar6:​ $var6" ​            
 </​code>​ </​code>​
-//(1) $0 a pour valeur pré-définie le nom du programme//\\ +>(1) $0 a pour valeur pré-définie le nom du programme
  
-**Retour :** 
 <​code>​ <​code>​
 valeur de var1: a valeur de var1: a
Ligne 75: Ligne 81:
 </​code>​ </​code>​
  
-  * **On peut déclarer plusieurs variables sur une même ligne, il suffit pour cela de mettre un espace entre chacune :**+===Déclaration de plusieurs variables sur une ligne=== 
 +On peut déclarer plusieurs variables sur une même ligne, il suffit pour cela de mettre un espace entre chacune :
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
Ligne 84: Ligne 91:
 </​code>​ </​code>​
  
-<​note>​ +<​note ​important
-**Le nom d'​une ​variable ​peut être fait des lettres de a-z ou de A-Z ; contenir ​des chiffres de 0-9 (mais précédé d'une ou plusieurs lettres minuscules ou majuscules).\\ +Le __nom d'​une ​variable__ ​peut être composé :  
-Il peut contenir un underscore _.\\  +  * par des lettres de a-z ou de A-Z ; 
-Mais il ne doit jamais commencer par un nombre ; par underscore ; un caractère spécial ;\\ +  * par des chiffres de 0-9 . 
-ni être un mélange de lettres minuscules et majuscules.**+  ​* ​Il peut contenir un underscore ​''​_''​.  
 +Mais il ne doit jamais ​
 +  * commencer par un nombre ;  
 +  * par underscore ;  
 +  * un caractère spécial ; 
 +  ​* ​ni être un mélange de lettres minuscules et majuscules.
 </​note>​ </​note>​
  
-  ​* **Voir "​l'​exemple 4.3. Affectation de variable, basique et plus élaborée"​ du : [[http://​abs.traduc.org/​abs-fr/​ch04s02.html|Guide avancé d'écriture des scripts Bash : "4.2. Affectation ​d'​une ​variable"]]** +  * Voir [[http://​abs.traduc.org/​abs-fr/​ch04s02.html|l'exemple ​4.3. Affectation ​de variable, basique et plus élaborée]] 
-  ​* ** Voir "​Variable nulle et variable non-déclarée dans l'​exemple "4.4. Entier ou chaîne de caractères ?" du : [[http://​abs.traduc.org/​abs-fr/​ch04s03.html|Guide avancé d'écriture des scripts Bash : "4.3. Les variables Bash ne sont pas typées"​]]**+  * Voir [[http://​abs.traduc.org/​abs-fr/​ch04s03.html|Variable nulle et variable non-déclarée dans l'exemple]]
  
 <note tip> <note tip>
Ligne 105: Ligne 117:
 </​note>​ </​note>​
  
-====2) Affectation par la lecture : read ==== +==== Affectation par la lecture : read ==== 
-**On peut créer des variables au moyen de commandes, comme par exemple la commande read qui est une commande interne (ou primitive) au shell.**+On peut créer des variables au moyen de commandes, comme par exemple la commande read qui est une commande interne (ou primitive) au shell.
  
-  *syntaxe ​:+  * Syntaxe ​:
 <​code>​ <​code>​
-read nom-de-la-variable+read nom_de_la_variable
 </​code>​ </​code>​
   *La valeur est enregistrée par l'​utilisateur sur l'​entrée standard (i.e. ce qu'on écrit à l'​invite de commande).\\ ​   *La valeur est enregistrée par l'​utilisateur sur l'​entrée standard (i.e. ce qu'on écrit à l'​invite de commande).\\ ​
Ligne 122: Ligne 134:
 echo "​Enchanté $nom !" echo "​Enchanté $nom !"
 </​code>​ </​code>​
-**De même dans le terminal on peut tout à fait entrer tour à tour chacune des lignes de ce script, essayez !** ;-)+<​note>​ 
 +De même dans le terminal on peut tout à fait entrer tour à tour chacune des lignes de ce script, essayez ! ;-) 
 +</​note>​
  
-  *L'​option -p permet d'​insérer un message avant l'​attente de la valeur que l'​utilisateur doit entrer.+  * L'​option -p permet d'​insérer un message avant l'​attente de la valeur que l'​utilisateur doit entrer.
  
 <code bash> <code bash>
Ligne 131: Ligne 145:
 echo "​bonjour $prenom !" echo "​bonjour $prenom !"
 </​code>​ </​code>​
-** Ici "prenom" ​est le nom de la variable, et sa valeur est entrée par l'​utilisateur depuis le terminal.** +>Ici ''​prenom'' ​est le nom de la variable, et sa valeur est entrée par l'​utilisateur depuis le terminal. 
-**Là aussi ces deux commandes peuvent être entrées dans le terminal.** +>Là aussi ces deux commandes peuvent être entrées dans le terminal. 
-  * read permet de déclarer plusieurs variables successivement (dans terminal ou script):+ 
 +  * ''​read'' ​permet de déclarer plusieurs variables successivement (dans terminal ou script):
 <code user> <code user>
 read -p "​entrez votre nom et prénom: " nom prenom read -p "​entrez votre nom et prénom: " nom prenom
 </​code>​ </​code>​
-retour: 
 <​code>​ <​code>​
 entrez votre nom et prénom: entrez votre nom et prénom:
 </​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 ​les deux chaînes de caractères,​ ''​debian''​ et ''​facile''​, puis on peut récupérer la valeur de chacune des deux variables ​''​nom'' ​et ''​prenom''​. 
 <code user> <code user>
 echo $prenom $nom echo $prenom $nom
 </​code>​ </​code>​
-retour : 
 <​code>​ <​code>​
 facile debian facile debian
 </​code>​ </​code>​
 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 à appeler la valeur de cette variable mais à permettre au programme de se poursuivre.\\ +  ​* read et variable non-déclarée ​
-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.+
    
 <code bash> <code bash>
Ligne 160: Ligne 174:
 </​code>​ </​code>​
  
 +>​Ci-dessus,​ on n'a pas mis le ''​nom''​ de la variable, parce qu'on ne cherchera pas 
 +>à utiliser la valeur de cette variable. Cela permet au programme de se poursuivre.
 +>Quand on entre dans le terminal la réponse attendu par ''​read'',​ le retour de la 
 +>​commande est ''​0'',​ donc elle est considérée comme exécutée, et le shell passe à
 +>​l'​exécution de la commande suivante.
 <​note>​ <​note>​
-**Les options de read les plus intéressantes.** +Quelques ​options ​utiles ​de la commande ''​read''​
-  * -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>​
  
-===== Déclaration nulle et modification par le script ​d'​une ​valeur interne ou externe====+====Modification de la valeur ​d'​une ​variable ​====
-**Pré-requis : utiliser les structures de contrôle** +
-Voir :  +
-  * **[[doc:​programmation:​shell:​avancee#​boucle-tant-que-while|boucle while]]** +
-  * **[[doc:​programmation:​shell:​avancee#​boucle-pour-tout-for|boucle for]]** +
-  * **[[doc:​programmation:​shell:​avancee#​selecteur-case|boucle case]]**+
  
-====Modifier ​la variable ​d'​une ​structure ​de contrôle par une valeur ​appelée dans le script==== +Pour modifier ​la valeur ​d'​une ​variable, il suffit ​de l'​affecter d'une nouvelle ​valeur. 
-<​code>​+<​code ​bash>
 #!/bin/bash #!/bin/bash
-for i in "​$@"​ +var1=bonjour 
- do +echo $var1 
-   ​echo "Vous avez donné à la variable '​i'​ la valeur : $i." +var1=23 
-    +echo $var1 
-   if [ "​$1"​ !"​coucou"​ ] ; then +var1= 
-      echo "Le premier argument doit être '​coucou'​."​ +echo $var1 
-    ​else ​ +var1=Bonjour 
-      echo "​OK"​ +echo $var1 
-     if [ "​$2"​ !"​toi"​ ] ; then +</​code>​
-        echo "Le deuxième paramètre doit être '​toi'​."​ +
-       else  +
-        echo "​MERCI"​ +
-     fi +
-   fi +
- ​done +
-echo " " #pour sauter une ligne+
  
-echo $@+<​code>​ 
 +bonjour 
 +23 
 + 
 +Bonjour
 </​code>​ </​code>​
  
-Ci-dessus, la variable i de la boucle prend tour à tour la valeur des paramètres passé au script depuis le terminal et la structure if teste si la chaîne du paramètre passé au script (valeur ​de la variable) correspond au motif voulu.\\+====Protection ​de variable ​: "​readonly"​ ====
  
-====Modifier ​une variable ​déclarée dans le script par une structure ​de contrôle====+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 variable en lecture seule, y compris si cette variable a été déclarée nulle. 
 +<code bash> 
 +#​!/​bin/​bash 
 +var1=toto 
 +var2= 
 +echo "$var1 $var2"​ 
 +readonly var1 var2 
 +var1=titi 
 +var2=titi 
 +unset var1 var2 
 +</​code>​ 
 +<​code>​ 
 +toto  
 + ​ligne6:​ var1 : variable en lecture seule 
 + ​ligne7:​ var2 : variable en lecture seule 
 + ligne 8 : unset: var1 : « unset » impossible : variable est en lecture seule 
 + ligne 8 : unset: var2 : « unset » impossible : variable est en lecture seule 
 +</​code>​ 
 + 
 +==== Suppression ​de variable : unset==== 
 +Soit le script "​essai.sh"​ : passons à ce script l'​argument ''​vous''​
  
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
-set a b c +var1=coucou 
-     ​echo "Avec '​shift',​ on se décale d'un paramètre à chaque boucle."  +var2=$1 
-           +echo "$var1 $var2
-for i in "$@+unset var2 
-do +echo "$var1 $var2
-i=$1 +var1=$1 
-shift 1 +var2=vous 
-echo "les paramètres sont : $1 :$2 :$3 .+echo "$var1 $var2"​ 
-done+unset var2 
 +echo "$var1 $var2"​ 
 +</​code>​ 
 + 
 +<​code>​ 
 +#​!/​bin/​bash 
 +var1=yep 
 +var2=coucou 
 +echo "$var1 $var2"​ 
 +unset var2 
 +echo "$var1 $var2"​ 
 +echo " " 
 +echo "mais pour un paramètre ​:
 +echo " " 
 +var1=yep 
 +var2=coucou 
 +var3=$1 
 +echo "$var1 $var2 $var3
 +unset var2 var3 
 +echo "$var1 $var2 $var3"​ 
 +var2= 
 +var3=$1 
 +echo "$var1 $var2 $var3"
 </​code>​ </​code>​
-Retour: 
  
 <code bash> <code bash>
-Avec '​shift',​ on se décale d'un paramètre ​à chaque boucle. +yep coucou 
-les paramètres sont b :c : . +yep  
-les paramètres sont : c : : . +  
-les paramètres sont :  : : .+mais pour un paramètre : 
 +  
 +yep coucou  
 +yep   
 +yep
 </​code>​ </​code>​
  
-===== Déclarer des paramètres de position : set===== 
-==== syntaxe de set==== 
-À savoir : variables de substitution prédéfinies [[atelier:​chantier:​bash-les-differents-caracteres-speciaux?&#​variables-de-substitution-predefinies-principalement-dans-les-scripts]] 
  
-  *La commande **set** permet ​d'affecter ​une valeur ​provisoire ​à un ou plusieurs paramètres de position. +==== Exportation de la valeur ​d'​une ​variable==== 
-Les arguments de la commande set seront les valeurs des paramètres que set positionne.\\ +=== Définition === 
 +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>​
 +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é.
 +Sur la notion de processus voir [[atelier:​chantier:​bash-les-differents-caracteres-speciaux?&#​notion-de-processus|Notion de processus]]
 +</​note>​
 +
 +=== Exemple ===
 +On peut exporter depuis le terminal, une valeur pour remplacer provisoirement une variable d'un script.
 +<code user>
 +Coucou="​Bonjour"​
 +</​code>​
 +>On déclare la variable ''​Coucou'',​ affectée de la valeur ''​Bonjour''​ depuis le terminal.
 +>Le shell courant l'a enregistré.
 +<code user>
 +echo 'echo "​Coucou=$Coucou"'​ > test.sh
 +</​code>​
 +>Là, on crée le fichier "​test.sh"​ contenant la ligne : ''​ echo "​Coucou=$Coucou"​ ''​.
 +>Il contient une variable, de même nom que celle, précédemment déclarée et affectée de la valeur ''​Bonjour''​ depuis le terminal.
 +<code user>
 +chmod u+x test.sh
 +</​code>​
 +>Le fichier "​test.sh"​ devient exécutable pour l'​utilisateur principal.
 +<code user>
 +export Coucou
 +</​code>​
 +>On exporte la variable ''​Coucou''​((Il s'agit ben sûr, de celle déclarée dans le terminal au début de l'​exemple)).
 +>​Attention,​ ce n'est jamais la __valeur__ d'une variable que l'on exporte !
 +<code user>
 +./test.sh
 +</​code>​
 <​code>​ <​code>​
-set argument1 [argument2] ...+Coucou="​Bonjour"​
 </​code>​ </​code>​
  
-<code bash> +>Il faut que le script déclare une variable de même nom (''​Coucou''​) ; qu'il récupère celle exportée depuis le terminal (''​$Coucou''​) ; et bien évidemment,​ qu'il affiche (''​echo''​) tout cela :( ''​echo "Coucou=$Coucou" ​''​). 
-#​!/​bin/​bash + 
-var=lettres +>Dans ces conditions, la valeur de la variable ''​Coucou''​ une fois exportée, peut valoir pour la variable du script ​"test.sh" ​qui est le __processus fils__ du shell courant. 
-set a b c               #​affectation des paramètres a b c + 
-echo "$var" "$1" "$2" ​"$3" +>Mais une fois __le terminal réinitialisé__,​ si on lance ./test.sh, ce script est le  
-if [ $# != 2 ] ; then   # ​(1) +>​processus fils d'​un ​"nouveau" ​processus père (= le nouveau terminalqui n'plus  
-echo "il y trois paramètres et une variable nommée var de valeur ​\"​lettres\"​ " +> en mémoire la valeur ​''​Bonjour''​ pour la variable nulle ''​Coucou''​ du script. 
-fi+>Et dans ce cas : 
 +<code user> 
 +./test.sh
 </​code>​ </​code>​
-Retour : 
  
 <​code>​ <​code>​
-lettres a b c +Coucou=
-il y a trois paramètres et une variable nommée var de valeur "​lettres"​+
 </​code>​ </​code>​
-**Observez:​** +  
-  * mon-script1 +<note
-<code bash+__Pour réinitialiser son terminal__,​\\ ​ 
-#​!/​bin/​bash +il suffit ​de fermer et de le ré-ouvrir\\ 
-set a b c  +ou de recharger son fichier ~/​.bashrc ​
-echo $@ +<code user> 
-echo "il y a les paramètres ​de position ​$1, $2, $3" +source ~/.bashrc
-echo "Leurs valeurs sont vide: RIEN"​$a",​ RIEN"​$b",​ RIEN"​$c"​."+
 </​code>​ </​code>​
-Retour : + 
-<​code ​bash+ou  
-a b c + 
-il y a les paramètres de position : a, b, c +<​code ​user
-Leurs valeurs sont vide: RIEN, RIEN, RIEN.+~/.bashrc
 </​code>​ </​code>​
-====set annule ​les paramètres de position ​affectés précédemment====+</​note>​ 
 +=====Quand ​les valeurs sont des paramètres ​===== 
 +<​note>​ 
 +On peut considérer que les termes paramètre et argument sont synonymes.\\ 
 +Le terme paramètre ​de position, renvoie à l'​appel de la valeur des paramètres (ou arguments) passés au script. 
 +</​note>​ 
 +====Utiliser des paramètres de positions ==== 
 + 
 +Lorsqu'​on ajoute un argument au script avant son exécution, on peut alors récupérer la valeur de ce paramètre.\\ 
 + 
 +  * Pour récupérer chaque paramètre : $1 ; $2 ; $3 etc. 
 + 
 +  * Pour récupérer tous les paramètres : $@ 
 + 
 +EXEMPLES : soit le script "​essai.sh"​
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
-var=lettres +var=Bonjour
-set a b c+
 echo $var echo $var
-echo $@ +echo "$1" ​ 
-echo " " ​ +echo "$2
-set gros_pater +echo "$3" 
-echo $var +echo "ou le paramètre 1 est: $1, le deuxième est: $2, le troisième est : $3" 
-echo $1 +echo " " 
-set -- +echo "tous les paramètres ​$@"
-echo $var  +
-echo $1+
 </​code>​ </​code>​
-**Retour :**+ 
 +<code user> 
 +./essai.sh a b c  
 +</​code>​ 
 <​code>​ <​code>​
-lettres +Bonjour ​ # on peut récupérer une valeur (ou des valeurs) déclarée(s) et les paramètres de position 
-a b c+a 
 +
 +
 +ou le paramètre 1 est: a, le deuxième est: b, le troisième est : c
    
-lettres +tous les paramètres a b c
-gros_pater +
-lettres +
 </​code>​ </​code>​
-====Paramètres de position ​et boucles==== + 
-Par exemple : soit le script ci-dessous boucle-set.sh\\  +  * Tous les arguments passés au scripts $* et $@ sont synonymes
-(passer un argument à ce script depuis le terminal)+
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
-var=$1 
 echo $1 echo $1
-set a b c +echo $*
-#set --+
 echo $@ echo $@
-  +echo $#
-for i in "​$@"​ +
-do +
-i=$1 +
- +
-echo "les paramètres sont : $1 :$2 :$3 ." +
-shift 1 +
-echo $var +
-done+
 </​code>​ </​code>​
 +
 <code user> <code user>
-./boucle-set.sh +./essai.sh bonjour à tous
 </​code>​ </​code>​
-Retour : 
-<code user> 
-a b c 
-les paramètres sont : a :b :c . 
  
-les paramètres sont : b :c : . +<​code>​ 
- +bonjour 
-les paramètres sont : c : : .+bonjour à tous 
 +bonjour à tous 
 +
 +</​code>​
  
-~$+  * Là de même pour $* et $@ : 
 +<code bash> 
 +#​!/​bin/​bash 
 +echo $1 
 +echo $* 
 +echo $@ 
 +echo $#
 </​code>​ </​code>​
-PUIS+
 <code user> <code user>
-./boucle-set.sh argument1+./essai.sh "​bonjour à tous"
 </​code>​ </​code>​
  
-retour : 
 <​code>​ <​code>​
-argument1 +bonjour à tous 
-a b c +bonjour à tous 
-les paramètres sont : a :b :c . +bonjour à tous 
-argument1 +1
-les paramètres sont : b :c : . +
-argument1 +
-les paramètres sont : c : : . +
-argument1+
 </​code>​ </​code>​
  
-====H ) Supprimer ​les paramètres ​de position==== +  * Mais avec la commande set qui modifie provisoirement ​les paramètres ​: 
-===Exemple=== +Pour plus de détails sur la commande set voir : [[atelier:​chantier:​script-bash-detail-sur-les-parametres-et-les-boucles?&​#syntaxe-de-set]] 
-**même ​script ​que ci-dessus mais on dé-commente set - - (on enlève ​ligne 5) :**+<code bash> 
 +#​!/​bin/​bash 
 +set "​bonjour à tous"​ 
 +echo $* 
 +echo $@ 
 +echo $1 
 +echo $# 
 +</​code>​
  
 <code user> <code user>
-./boucle-set.sh +./essai.sh
 </​code>​ </​code>​
  
-retour ​:+<code > 
 +bonjour à tous 
 +bonjour à tous 
 +bonjour à tous 
 +
 +</​code>​ 
 + 
 +  * Ou encore ​:
  
 <​code>​ <​code>​
 +#!/bin/bash
 +set bonjour à tous
 +echo $*
 +echo $@
 +echo $1
 +echo $#
 +</​code>​
  
-~$+<code user> 
 +./essai.sh
 </​code>​ </​code>​
  
-et+<code > 
 +bonjour à tous 
 +bonjour à tous 
 +bonjour 
 +3
  
-<code user> 
-./​boucle-set.sh argument1 
 </​code>​ </​code>​
  
-retour :+=====Récupérer la longueur d'une valeur de variable=====
  
 +  * Pour obtenir la longueur d'une chaîne stockée dans une variable, on écrit ''​${#​VAR}''​.
 +
 +Exemples :
 +<code bash>
 +#!/bin/bash
 +var="​j'​aime debian-facile"​
 +echo ${#var}
 +</​code>​
 +
 +  * Pour récupérer la longueur d'un paramètre de position :
 +FIXME
 +
 +
 +
 +=====Substitutions de commande=====
 +===Utilisation ===
 +Permet de se servir de la sortie d'une commande dans un autre contexte pour ;
 +  - affecter cette sortie à une variable ;
 +  - utiliser cette sortie comme argument d'une autre commande
 +  - etc.
 +
 +===Deux syntaxes :===
 <​code>​ <​code>​
-argument1+`commande` 
 +</​code>​
  
-~$+OU 
 + 
 +<​code>​ 
 +$(commande)
 </​code>​ </​code>​
-====Attention à la commande set : les arguments passés au script sont supprimés==== ​ 
-**Elle supprime toute possibilité de se référer à des paramètres passés au script (depuis le terminal),​\\ ​ 
-et ceci y compris si on supprime avec set - - les paramètres de position déclarés avec set.**\\ ​ 
  
 +====Substitution simple : $(commande)====
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
-#donner les argument 1 2 3 à se script avant de le lancer +dir=$(pwd) 
-var1=$1 ; var2=$2 ; var3=$3 +echo "mon répertoire est : $dir" 
-echo "les valeurs de var1, var2 et var3 sont les paramètres de position ​: $@.+</​code>​ 
-echo " " +<​code>​ 
-for i in "$@" +mon répertoire est : /​home/​hypathie 
-do +</​code>​ 
-echo "les paramètres de position sont : $1 :$2 :$." +  *plusieurs commandes:​ 
-shift 1 +<code bash> 
-done+#!/bin/bash 
 +echo $(pwd ; ls) 
 +</​code>​ 
 +====Imbrication de commandes : $(cmd $(cmd))==== 
 +<code bash> 
 +echo $( ls $(pwd)/​Documents) 
 +</​code>​ 
 +=== Imbrication avec ''​set''​ === 
 +<code bash> 
 +#​!/​bin/​bash 
 +set $(pwd ; whoami) 
 +echo "$1 : $2
 +echo $
 +</​code>​ 
 +Ou  
 +<code bash> 
 +#​!/​bin/​bash 
 +set -- $(ls -l $(pwd)/.bashrc) 
 +echo $* 
 +</​code>​
  
-set b c +=====Typologie des variables ===== 
-set -- +Comme nous l'​avons vu on peut affecter une variable par différents types de valeurs ; des chaînes de caractères,​ des nombres, des valeurs d'​autres variables, des substitutions de commandes.\\  
-for i in "$@" +On dit pour cela qu'en bash les variables ne sont pas typées.\\ 
-do +Mais il peut être intéressant de typer une variable. Pour ce faire, il faut utiliser des commandes internes à bash qui permettent de déclarer une variable typée.\\ 
-echo "les paramètres sont $1 :$2 :$3 ." + 
-done +====declare et typeset ====  
-echo " " +^ commandes ​     ^options ​                 ^ 
-echo "les paramètres ​de position sont "​$@"​." +|declare/​typeset |''​-r''​ : lecture seule   | 
-echo "les valeurs 1, 2, et 3 sont maintenant les valeurs des variables ​$var1 ; $var2 ; $var3."​+|declare/​typeset |''​-i''​ : entier ​         | 
 +|declare/​typeset |''​-a''​ tableau (array) ​  | 
 +|declare/​typeset |''​-f''​ : fonction(s) ​    | 
 +|declare/​typeset |''​-x''​ : export ​         | 
 +|declare/​typeset |''​-x''​ : ''​var=$valeur''​ | 
 + 
 +Voir [[http://​abs.traduc.org/​abs-5.1-fr/​ch09s04.html|Guide avancé d'​écriture des scripts Bash9.4. Typer des variables : declare ou typeset]] 
 + 
 +===Remarques sur la commande ​"declare" ​et les calculs === 
 + 
 +<note important>​ 
 +**Méthode non POSIX**\\ 
 +  * La valeur d'une variable peut une expression arithmétique,​ pour initialiser une variable ​de type entier on utilise l'​option ''​-i''​ de la commande ''​declare''​ :\\ ''​declare -i nom[=expression] nom[=expression] ​...''​ 
 + 
 +<code bash> 
 +#​!/​bin/​bash 
 +declare -i x=35*2 
 +echo $
 +</​code>​ 
 +retour 
 +<​code>​ 
 +70
 </​code>​ </​code>​
  
-Retour :+  * Pour que la valeur d'une variable ne soit pas accidentellement modifier, il faut ajouter l'​attribut ''​-r''​.
  
 +<code bash>
 +#!/bin/bash
 +declare -ir a=35*2
 +declare -ir b=5+5
 +echo $(($a+$b))
 +</​code>​
 +
 +<​code>​
 +80
 +</​code>​
 +
 +**Méthode POSIX** : Les commandes ''​let''​ et ''<​nowiki>​(( ... ))</​nowiki>''​ permettent de typer les variables pour effectuer des calculs sur les variables (synonyme de ''​declare -i''​).
 +</​note>​
 +
 +
 +===== Variables numériques et calculs =====
 +
 +==== Les variables typées pour les calculs : let ou (( ... )) ====
 +Voir : [[atelier:​chantier:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques?&#​operateurs-arithmetiques|les opérateurs arithmétiques]] ​
 +===Syntaxe===
 +<​code>​
 +let 'var = 5 + 5'
 +      OU LE SHELL ARITHMÉTIQUE :
 +$(( 5 * 3 ))
 +</​code>​
 +=== Exemples===
 +<code bash>
 +#!/bin/bash
 +let "a = 10"
 +let "b = 2"
 +let "c = a+b"
 +echo $c
 +let "e = 10*2"
 +echo $e
 +let "f = 15"
 +let "f *=2"
 +echo $f
 +echo " "
 +let 'var = 5 + 5'
 +echo "​$var"​
 +echo " "
 +echo $(( 20 + 20 ))
 +var1="​2"​
 +var2="​5"​
 +echo $(( $var2 % $var1 ))
 +</​code>​
 <​code>​ <​code>​
-les valeurs de var1, var2 et var3 sont les paramètres de position : 1 2 3.+12 
 +20 
 +30
    
-les paramètres de position sont : 1 :2 :3 . +10
-les paramètres de position sont : 2 :3 : . +
-les paramètres de position sont : 3 : : .+
    
-les paramètres de position sont . +40 
-les valeurs ​1, 2, et 3 sont maintenant les valeurs des variables 1 ; 2 ; 3.+1
 </​code>​ </​code>​
-====remarques sur set ==== + 
-<note +==== L'​affectation arthmétique==== 
-  *Sans argument ​la commande set affiche TOUS les noms et TOUTES les valeurs des variables pré-définies ​(celles du script qui l'appelle aussi). Mais elle n'enregistre pas une valeur d'un valeur non-déclarée ! FIXME\\+Voir [[atelier:​chantier:​page-man-bash-iv-symboles-dans-les-calculs-mathematiques?&#​operateurs-d-affectation-arithmetique| les opérateurs d'​affectation arithmétique]] 
 + 
 +Cela consiste à affecter à une variable le résultat d'un calcul arithmétique,​ par la __constante__ (donc avec ''​let''​) qu'on lui a donné.\\  
 +Soit une variable var de valeur x, si l'on fait  ''​var +=2''​ alors la variable var sera ''​x + 2''​.\\  
 + 
 +>cela permet de faire des incrémentation par autre chose que 1.) 
 +>Il en va de même pour les autres opérateurs.\\ 
 + 
 +  * Exemples 
 + 
 +<code bash> 
 +let "a = 5" 
 +let "b = 10" 
 +let "c = a *= 3" 
 +let "d = a += 3" ​    # valeur précédente de a conservée pour calculer d : 15+3 =18 
 +let "e = b /= 3" 
 +let "f = b /= 3" ​   # valeur précédente de b conservée pour calculer f : 3/3 =1 
 +echo "c=$c d=$d e=$e f=$f" # réponse : c=15 d=18 e=3 f=1 
 +i=1 
 +let "i += 7" 
 +echo "​i=$i" ​       # réponse : i=8 
 +j=4 
 +let "j *= 5" 
 +echo "​j=$j" ​       # réponse : j=20 
 +</​code>​ 
 + 
 +===Incrémentation,​ décrémentation=== 
 + 
 +  * incrémentation,​ décrémentation de la valeur 1 : ''<​nowiki>​(( var++ ))</​nowiki>​'' ; ''<​nowiki>​(( ++var ))</​nowiki>​'' ​; ''<​nowiki>​(( var-- ))</​nowiki>'',​ etc. 
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
-var=lettres +let "var = 5" 
-set a b c +echo "​$var"​ 
-set+(( var++ )) 
 +echo "​$var"​ 
 +(( var-- )) 
 +echo "​$var"​
 </​code>​ </​code>​
-Observons les deux dernières lignes du retour ​:+Retour ​: 
 <​code>​ <​code>​
-XDG_SESSION_PATH=/​org/​freedesktop/​DisplayManager/​Session0 +5 
-_=c +6 
-var=lettres+5
 </​code>​ </​code>​
-La première ligne montre en majuscule le nom d'une variable pré-défini,​ et ce qui suit est la valeur de cette variable. +<note tip> 
-Nous retrouvons la variable var de notre script avec sa valeur "​lettres"​. +  * L'incrémentation se fait aussi sur une boucle !  
-Mais on ne voit pas les paramètres a b c. +
-  *set -o nom-de-l'option ou set -abréviation-de-l'​option: ​ permet d'​activer les options du shell dans un script.\\ +
-Par exemple, on peut vérifier grâce à un message d'​erreur si on appelle la valeur d'un paramètre qui n'a pas été défini.+
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
-set -o nounset +i=1 # on initialise le compteur 
-var=a +while [ $i -le 10 ]; do 
-var1+  echo $i 
- +  ​let ​$[ i+=1 ] # incremente i de 1 a chaque boucle 
-echo $var  +done
-echo $var1 +
-echo $var3+
 </​code>​ </​code>​
-retour ​: +[[atelier:chantier:​script-bash-les-tableaux#​se-creuser-un-peu-les-meninges|voir aussi ici]] 
-<​code>​ +
-a+
  
-/​home/​hypathie/​MesScripts/​scriessligne8: var3 : variable sans liaison+  * Ou encore de cette manière ​: 
 +<code bash> 
 +N=$(($N+1))
 </​code>​ </​code>​
-Voir le tableau des options icihttp://​abs.traduc.org/​abs-5.3-fr/​ch30.html#optionsref+[[doc:programmation:shell:​avancee#les-fonctions|voir ici le code complet de cet extrait]] ​
 </​note>​ </​note>​
 +====Changements de bases ====
 +Bash permet de changer de base (Il est par défaut en base 10)\\
 +  * base 8 (octal) : un chiffre n précédé de zéro : ''​0n''​\\
 +exemple : 02 => 2 en base 8
 +  * base 16(hexadécimal):​ un chiffre n précédé de zéro+x : ''​0xn''​\\
 +exemple : 0x3 => 3 en base 16
 +  * autres bases : ''​base#​nombre''​
 +  * base maximale : base 64
 +
 +=====Références =====
 +
 +[[doc:​programmation:​shell:​shell#​variables-et-environnement|Le shell pour tous : "​Variables et environnement"​]]\\ ​
 +[[doc:​programmation:​shell:​variables]]\\
 +[[http://​abs.traduc.org/​abs-fr/​ch04.html|Guide avancé d'​écriture des scripts Bash : Introduction aux variables et aux paramètres]]
 +
 +
 +=====La suite c'est ici =====
 +[[atelier:​chantier:​script-bash-detail-sur-les-parametres-et-les-boucles|script-bash-detail-sur-les-parametres]]
doc/programmation/shells/script-bash-variables-arguments-parametres.txt · Dernière modification: 23/02/2023 02:20 par agp91

Pied de page des forums

Propulsé par FluxBB