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:debuter-avec-les-scripts-shell-bash [28/05/2014 07:25]
Hypathie [Création de variables par l'utilisateur]
doc:programmation:shells:debuter-avec-les-scripts-shell-bash [30/05/2014 07:03]
Hypathie [Variable et substitution de commandes]
Ligne 284: Ligne 284:
 **Lors de l'​exécution de ce script, la chaîne que vous entrerez pour répondre à la question, sera le nom d'un nouveau script que vous voulez créer.** **Lors de l'​exécution de ce script, la chaîne que vous entrerez pour répondre à la question, sera le nom d'un nouveau script que vous voulez créer.**
 ===== Création de variables par l'​utilisateur===== ===== Création de variables par l'​utilisateur=====
-En liens : \\ +En liens nécessaires ​: \\ 
 [[doc:​programmation:​shell:​shell#​variables-et-environnement|Le shell pour tous : "​Variables et environnement"​]]\\ ​ [[doc:​programmation:​shell:​shell#​variables-et-environnement|Le shell pour tous : "​Variables et environnement"​]]\\ ​
 [[doc:​programmation:​shell:​variables]] [[doc:​programmation:​shell:​variables]]
- + 
-Dans un script la ou les commandes qui y sont regroupées vise un résultat pour une valeur initiale donnée.\\  +
-Les variables servent à stocker une valeur dans la mémoire de la machine. Une fois cette valeur mémorisée,​ on peut alors l'​interroger (ou la tester), pour la connaître en détail et/ou la transformer.\\ Par exemple la valeur d'une variable peut être un répertoire contenant des fichiers que l'on veut réorganiser,​ en utilisant des commandes sur cette variable, elle va alors changer et le résultat de cette transformation sera par exemple la réorganisation du fichier.\\  +
-Autre exemple, une variable peut être un programme, faire changer la valeur de la variable consistera par exemple à maîtriser le déroulement de ce programme. On peut les utiliser encore pour effectuer des opérations arithmétiques,​ des manipulations quantitatives ou pour le traitement des chaînes de caractères d'un texte, etc.\\ ​ +
 **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.**\\ ​
  
-**Enfin, les variables qu'on crée dans un script sont localisées dans ce script (à moins de les exporter) c'​est-à-dire qu'​elles ne sont utilisables que lorsqu'​on exécute son script, ​et comme il s'agit du script d'un utilisateur, ​on peut les appeler variables de l'​utilisateur. Cela permet de 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 ?**\\ 
Ligne 305: Ligne 302:
    
   * **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>​
 #!/bin/bash #!/bin/bash
Ligne 313: Ligne 310:
  
   * **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** :\\    * **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** :\\ 
-  * **Voir : [[atelier:​chantier:​la-page-man-bash-les-caracteres-speciaux#​details-sur-le-caractere|détail sur le caractère $]]**+ 
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
Ligne 367: Ligne 364:
  
 ====2) Affectation par la lecture : read ==== ====2) 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.**
 +
   *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).\\ ​
 +  *Le nom de la variable s'​écrit juste après read, ce n'est qu'un pointeur vers la valeur que vous avez rentrée.
  
-Par exemple:+Par exemple ​dans un script ​:
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
Ligne 379: Ligne 380:
 echo "​Enchanté $nom !" echo "​Enchanté $nom !"
 </​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).\\  +**De même dans le terminal ​on peut tout à fait entrer tour à tour chacune des lignes ​de ce script, essayez !** ;-
-  *Le nom de la variable s'​écrit juste après read, ce n'est qu'un pointeur vers la valeur que vous avez rentrée.+
   *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.
  
Ligne 388: Ligne 389:
 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.** 
 +**Là aussi ces deux commandes peuvent être entrées dans le terminal.** 
 +  * read permet de déclarer plusieurs variables successivement (dans terminal ou script): 
 +<code user> 
 +read -p "​entrez votre nom et prénom: " nom prenom 
 +</​code>​ 
 +retour: 
 +<​code>​ 
 +entrez votre nom et prénom: 
 +</​code>​ 
 +On entre par exemple debian facile, puis on peut récupérer la valeur de chacune des variables "​nom"​ et "​prenom"​ 
 +<code user> 
 +echo $prenom $nom 
 +</​code>​ 
 +retour : 
 +<​code>​ 
 +facile debian 
 +</​code>​ 
 +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.\\ 
 +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>
 #!/bin/bash #!/bin/bash
Ligne 394: Ligne 417:
 echo "​bonjour $USER !" echo "​bonjour $USER !"
 </​code>​ </​code>​
-=====Créer des paramètres de position : la commande set + argument(s)=====+ 
 +<​note>​ 
 +**Les options de read les plus intéressantes.** 
 +  * -p : afficher un message 
 +  * -n : limiter le nombre de caractères 
 +  * -t : limiter le temps autorisé pour saisir un message 
 +  * -s : ne pas afficher le texte saisi 
 +par exemple:  
 +  read -p "​entrez votre de naissance (deux derniers chiffres): " -n 2 annee 
 +</​note>​ 
 +=====Créer des paramètres de position : la commande set =====
  
 À savoir : variables de substitution prédéfinies [[atelier:​chantier:​bash-les-differents-caracteres-speciaux?&#​variables-de-substitution-predefinies-principalement-dans-les-scripts]] À 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 à un ou plusieurs paramètres.+  *La commande **set** permet d'​affecter une valeur ​provisoire ​à un ou plusieurs paramètres ​de position.
 Les arguments de la commande set seront les valeurs des paramètres que set positionne.\\ ​ Les arguments de la commande set seront les valeurs des paramètres que set positionne.\\ ​
  
Ligne 408: Ligne 441:
 #!/bin/bash #!/bin/bash
 var=lettres var=lettres
-set a b c                     ​#​affectation des paramètres a b c +set a b c               ​#​affectation des paramètres a b c 
-echo $var $1 $2 $3 +echo "$var" "$1" "$2" "$3" 
-if [ $# != 2 ] ; then         ​# (1)+if [ $# != 2 ] ; then   ​# (1)
 echo "il y a trois paramètres et une variable nommée var de valeur \"​lettres\"​ " echo "il y a trois paramètres et une variable nommée var de valeur \"​lettres\"​ "
 fi fi
Ligne 420: Ligne 453:
 il y a trois paramètres et une variable nommée var de valeur "​lettres"​ il y a trois paramètres et une variable nommée var de valeur "​lettres"​
 </​code>​ </​code>​
-//(1) Cette ligne signifie : si (if) le nombre de paramètres ($#) est différent de 2 (!= 2) alors (then).//​\\ ​ 
 Voir : [[doc:​programmation:​shell:​avancee#​instruction-conditionnelle-if]] Voir : [[doc:​programmation:​shell:​avancee#​instruction-conditionnelle-if]]
  
 **Remarquez : Dans cet exemple, les valeurs des paramètres enregistrés grâce à la commande set sont stockés en mémoire de façon identique que l'​enregistrement de la valeur "​lettres"​ de la variable "​var"​ au moyen du signe =.\\ Autrement dit, la commande interne set est un mécanisme d'​enregistrement d'une valeur qui n'a pas besoin d'​être nommée pour être pointée.\\ ​ **Remarquez : Dans cet exemple, les valeurs des paramètres enregistrés grâce à la commande set sont stockés en mémoire de façon identique que l'​enregistrement de la valeur "​lettres"​ de la variable "​var"​ au moyen du signe =.\\ Autrement dit, la commande interne set est un mécanisme d'​enregistrement d'une valeur qui n'a pas besoin d'​être nommée pour être pointée.\\ ​
-Et dans ce cas, un paramètre c'est une valeur ou encore une "​variable"​ un peu particulière,​ voyons ce qui fait qu'un paramètre ce n'est pas une variable** +Et dans ce cas, un paramètre c'est une valeur ou encore une "​variable"​ un peu particulière,​ voyons ce qui fait que la valeur d'un paramètre ce n'est pas exactement la valeur d'une variable** 
-   ​* **Remarquez d'​abord cela :**+ 
 +**Observez:** 
 +  * mon-script1
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
-set a b c            # ici les valeurs exactes des paramètres sont mémorisées dans le script +set a b c  
-echo $1 $2 $3 +echo $@ 
-if [ $# != $1:$2:$3 ] ; then +echo "il y a les paramètres de position : $1$2$3" 
-echo "Les valeurs ​des paramètres 1, 2, et 3, sont a b c." +echo "Leurs valeurs sont vide: RIEN"$a", RIEN"$b", RIEN"$c"."
-fi+
 </​code>​ </​code>​
 Retour : Retour :
 <code bash> <code bash>
 a b c a b c
-Les valeurs des paramètres ​1, 2, et 3, sont a b c.+il y a les paramètres ​de position : abc 
 +Leurs valeurs sont vide: RIEN, RIEN, RIEN.
 </​code>​ </​code>​
  
-**=> La valeur d'un paramètre ​a une position ​précise ​!**+**=> La valeur d'un paramètre ​de position ​n'est pas pointé ​!**
  
-  * **remarquez maintenant ceci :**\\  +  * mon-script2 ​:
-Lancez : "mon-script"​ avec le contenu ci-dessous, comme vous l'avez fait jusqu'​ici ​:+
 <code bash> <code bash>
 #!/bin/bash #!/bin/bash
-if [ $# != 2 ]          # ici le mécanisme if ... then enregistre 2 chaînes peu importe lesquelles; le script enregistre en mémoire un test conditionnel par lequel sont enregistées les valeurs de deux paramètres qui peuvent être une chaîne de caractères indéterminée. ​ 
-then 
-echo " Il faut deux paramètres,​ svp !" 
-else  
-echo "vous avez rentré 2 paramètres : bravo !" 
-fi 
-</​code>​ 
- 
-Puis exécutez à nouveau ce script en ajoutant, avant d'​appuyer sur la touche entrée, un espace puis deux groupes de caractères (lettre(s) ou chiffre(s)) séparés par un espace.\\ ​ 
-Par exemple : 
-<​code>​ 
-mon.script bfr  u2f 
-</​code>​ 
- 
-**retour premier cas :** 
-<​code>​ 
-Il faut deux paramètres,​ svp ! 
-</​code>​ 
-**retour deuxième cas :** 
-<​code>​ 
-vous avez rentré 2 paramètres : bravo ! 
-</​code>​ 
- 
-**=> Contrairement à la valeur d'une variable, la valeur d'un paramètre (créé au moyen d'une conditionnelle) est pointée par cette conditionnelle sans que celle-ci soit forcément nommée.** 
- 
-  * **un paramètre n'est pas une variable ; tous les paramètres de position sont ré-initialisés dès que set pose un nouvel argument tandis qu'il ne réinitialise pas une variable déjà créée.** 
-  * ** De même, set-- annule tous les paramètres initialisés (pas la ou les variable(s)).** 
- 
-<code bash> 
 #!/bin/bash #!/bin/bash
 var=lettres var=lettres
 set a b c set a b c
-echo $var $1 $2 $3+echo $var 
 +echo $
 +echo " " ​
 set gros_pater set gros_pater
-echo $var $1+echo $var 
 +echo $1
 set -- set --
-echo $var $1+echo $var  
 +echo $1
 </​code>​ </​code>​
 **Retour :** **Retour :**
 <​code>​ <​code>​
-lettres ​a b c       # valeur de var et des paramètres ​a b c +lettres 
-lettres gros_pater ​ # valeur de var et du paramètre gros_pater (initialiser ce nouveau paramètre à effacer les paramètres a b c mais pas la variable var +a b c 
-lettres ​            # set-- rend indéfini la ou les valeur(s) des paramètres de position précédemment initialisés+  
 +lettres 
 +gros_pater 
 +lettres 
 + 
 </​code>​ </​code>​
 +  * **=> dans un script, contrairement à la valeur d'une variable, la valeur d'un paramètre de position créé avec set est ré-initialisé dès que set pose un nouvel paramètre de position, tandis qu'il est possible de déclarer une nouvelle variable au sein d'un même script.**
 +  * ** De même, set-- annule tous les paramètres position initialisés précédemment dans le script.**
 <note > <note >
   *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\\   *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\\
Ligne 528: Ligne 543:
 </​note>​ </​note>​
  
-===Les tableaux==+=====Déclaration ​de la valeur ​d'​une ​variable avec une structure conditionnelle===== 
-Les variables ​de chaque case d'un tableau, ont elles aussi une position définie par l'​utilisateur,​ ou automatiquement lors de la création du tableau.\\  + 
-Pour plus de précision sur la création et l'​utilisation de tableau dans les scripts voir ici : [[atelier:​chantier:​page-man-bash-v-les-tableaux]] +**La valeur du paramètre ​d'​une ​conditionnelle est pointée par cette conditionnelle sans forcément être nommé.** 
-=====Variable et substitution de commandes ​===== +(Lancez ​"mon-script" ​successivement sans argument, puis un, deux trois, etc. arguments.)
-  *$( ) +
-Une commande entourée par $( ) est exécuté puis la chaîne $(commande) peut être affectée à une variable.On peut donc appeler la valeur du retour ​d'​une ​commande.\\  +
-<code bash> +
-#​!/​bin/​bash +
-dir=$(pwd) +
-echo "​mon ​répertoire est : $dir" +
-</​code>​+
 <​code>​ <​code>​
-mon répertoire est : /​home/​hypathie 
-</​code>​ 
-  *plusieurs commandes: 
-<code bash> 
 #!/bin/bash #!/bin/bash
-echo $(pwd ; ls) +var1=$1 
-</​code>​ +var2=$2 
-On peut aussi imbriquer les commandes ainsi : +echo $1 
-<code bash> +echo $
-echo $( ls $(pwd)/​Documents) +if [ $# == 1 ] ; then 
-</​code>​ + echo "​ERREURvous avez entré $@, mais il faut deux arguments ​!" 
-  *avec set : +  elif [ $# == 2 ] then 
-<code bash> +   ​echo "Les deux arguments que vous avez entré sont $1 et $2" 
-#!/bin/bash +  elif [ $# == 0 ] ; then 
-set $(pwd whoami) +    echo "​ERREUR:​ vous n'avez pas entré d'​arguments,​ il en faut deux !" 
-echo "​$1 ​$2" +fi
-echo $# +
-</​code>​ +
-Ou  +
-<code bash> +
-#!/bin/bash +
-set -- $(ls -l $(pwd)/​.bashrc) +
-echo $*+
 </​code>​ </​code>​
  
-On ne confondra pas une paire de parenthèses précédée ​d'un $ avec une paire de parenthèse autour d'une suite de commandes !\\  +**Mais la valeur des paramètres ​d'​une ​conditionnelle peut être "​nommé"​ du nom de la variable "​i" ​d'​une ​boucle ​qui prend tour à tour la valeur ​de chacun des paramètres ​de position.**
-Voir chapitre suivant ;-) +
-=====enchaînements de commandes dans les scripts: utiliser ​la distinction code de retour/​résultat de commande===== +
-enchaînement de commandes : [[doc:​programmation:​shell:​shell#​enchainer-plusieurs-commandes]] +
-====1) Code de retour ​ et enchaînement de commande ==== +
-Le code de retour (exit status) est fourni par le shell après l'​exécution ​d'​une ​commande.\\  +
-Le code de retour est un entier positif ou nul. Par convention 0 est l'​état de sortie d'une commande ​qui s'est exécutée correctement. Tout autre entier indique un problème lors de l'​exécution d'une commande.\\  +
-Il ne faut pas confondre le code de retour et le résultat d'une commande. Le résultat est ce qui s'​inscrit sur la sortie standard+
  
-Il faut connaître ce mécanisme pour pouvoir choisir le ou les caractère(s) d'​enchaînement de commandes adapté(s) au résultat souhaité. 
- 
-**Les caractères d'​enchaînement de commandes** (que le trouve souvent sous le nom **d'​opérateurs de contrôle**) sont strictement ceux-ci :  
 <​code>​ <​code>​
-  &    && ​   ( )    { }    ;    ||  
-</​code>​ 
- 
-===Choisir les caractères d'​enchaînement de commandes en fonction de la gestion des flux === 
-Reprenons le script "​scriptx",​ et changeons les ";"​ d'​abord par "&",​ puis par "&&"​ 
-<code bash> 
 #!/bin/bash #!/bin/bash
-set -o posix +for i in "​$@"​ 
-printf ​"Un nouveau script utilisateur ​son nom ? " ​  + do 
-{ read nom && echo "#!/bin/bash" ​>> $nom && chmod u+x $nom && mv ~/$nom ~/​MesScripts && /​usr/​bin/​gedit ~/​MesScripts/​$nom ​;} +   ​echo ​"Vous avez donné à la variable '​i'​ la valeur ​$i.
-</​code>​ +    
-En mettant ​"&&" ​entre les commandes, ce script fonctionne aussi bien qu'​avec les ";". Mais avec "&", on obtiendrait un message d'erreur.\\  +   if [ "$1" !"coucou"​ ] then 
-Pourquoi ?+      echo "Le premier argument doit être '​coucou'​."​ 
 +    else  
 +      echo "OK" 
 +     if [ "$2" ​!= "toi" ​] ; then 
 +        echo "Le deuxième paramètre doit être 'toi'." 
 +       else  
 +        echo "​MERCI"​ 
 +     fi 
 +   fi 
 + ​done 
 +echo " " #pour sauter une ligne
  
-  * **L'​opérateur de contrôle "&"​ :** toutes les commandes sont exécutées parallèlement.\\ ​  +echo $@
-(Dans l'​exemple ci-dessus, chaque commande étant traitée par un sous-shell, la valeur d'une commande ne peut pas être conservée dans un même processus pour que chaque commande puisse "​travailler en rapport au RESULTAT de la commande précédente. Par exemple, il faut que le fichier créé soit "​connu"​ du shell pour qu'il puise être ouvert par "​gedit"​ dans ce même shell.) +
-  +
-  * **l'​opérateur ";"​ :** chaque commande est exécuté l'une après l'​autre,​ même si l'une d'elle a mal fonctionné.\\  +
-  +
-  * **L'​opérateur "&&"​ utilise le code de retour :** avec cet opérateur, chaque commande d'une suite est exécuté l'une après l'​autre si le code retour de la première est 0 (c'​est-à-dire si elle a fonctionné).\\  +
- +
-  * **L'​opérateur "​||"​ utilise le code de retour :** la commande suivante est exécutée si le code de retour de la première est différente de zéro, c'​est-à-dire si elle n'a pas fonctionné.  +
-<​note>​ +
-Dans l'​exemple avec "​scriptx",​ on a récupéré **la valeur d'une commande** pour s'en servir dans une succession de commandes.\\  +
-On n'a pas chercher à rediriger le résultat d'une commande vers un fichier ou le contenu d'un fichier vers une commande (excepté pour concaténer dans le fichier créé la première ligne du futur script). Pour le faire il faut utiliser les redirections,​ voir plus bas ;\\  +
-On n'a pas cherché non plus à transmettre le résultat d'une commande à une autre commande (tube |)  +
-</​note>​ +
-====2) Deux syntaxes : { suite-de-commandes ;} ou (suite-de-commandes;​)==== +
-le shell bash fournit deux mécanismes pour regrouper les commandes; l'​insertion de la suite de commandes entre accolades et l'​insertion de cette suite de commandes entre une paire de parenthèses. +
- +
-  * **{ suite-de-commandes ;}** +
-Les accolades sont des mots-clé de bash.\\  +
-Il ne faut donc pas oublier de mettre un **espace entre l'​accolade ouvrante et la première commande** de la liste. +
-Entre accolades, la valeur change commandes après commande ; le changement est conservé jusqu'​à la dernière commande parce que toutes les modifications sont faites dans le shell courant. +
-  +
-<code bash> +
-#​!/​bin/​bash +
-{ pwd ; cd ~/Documents ; echo $(pwd) ;}+
 </​code>​ </​code>​
-Retour : 
-<​code>​ 
-/​home/​hypathie 
-/​home/​hypathie/​Documents 
-</​code>​ 
-<​note>​ 
-Pour se servir des accolades pour conserver la valeur d'une variable et la faire changer de commande en commande, il ne faut pas terminer le regroupement de commandes par &​.\\ ​ 
-Car cela à pour effet de ne pas exécuter chaque commande dans le shell courant mais dans un sous-shell.\ ​ 
-<code bash> 
-#!/bin/bash 
-{ pwd ; cd ~/Documents ; echo $(pwd) ;} & 
-</​code>​ 
-retour : 
-<​code>​ 
-/​home/​hypathie ​   
-</​code>​ 
-# le prompt ne revient pas il faut faire ctrl+c ! 
-</​note>​ 
  
-**L'​utilisation du groupement ​de commande sert souvent ​à la redirection globale ​de l'​entrée du groupe ​de commande ou à sa sortie.** On le verra plus loin : [[atelier:​chantier:​debuter-avec-les-scripts-shell-bash?&#​combiner-enchainement-de-commandes-redirection-code-de-retour-dans-un-script]] +** On peut faire passer une boucle par des paramètres ​de position et faire prendre ​à sa variable tour à tour la valeur ​de ces paramètres ​de position.**\\ 
-  * **(suite-de-commandes;​)**+**Mais contrairement au script précédent,​ on ne peut alors plus ajouter des paramètres ​de l'​extérieur du script, depuis le terminal en ajoutant des arguments après le nom du script.** 
  
-Les parenthèses sont des opérateurs.\\ ​ +=====Créer ​des variables : les tableaux===== 
-Il n'y a donc pas besoin ​d'espace entre la parenthèse ouvrante et la première commande+Les variables de chaque case d'un tableau, ont elles aussi une position définie par l'​utilisateur,​ ou automatiquement lors de la création du tableau.\\  
-Insérée dans une parenthèse, ​la suite de commandes est exécutée ​dans un sous-shell.+Pour plus de précision sur la création et l'​utilisation ​de tableau ​dans les scripts voir ici : [[atelier:​chantier:​page-man-bash-v-les-tableaux]]
  
-<code bash> 
-#!/bin/bash 
-nom=dx 
-(nom=hypathie ; echo $nom) 
-echo $nom 
-</​code>​ 
-Retour : 
-<​code>​ 
-hypathie 
-dx 
-</​code>​ 
  
 =====Les redirections dans les scripts===== =====Les redirections dans les scripts=====
doc/programmation/shells/debuter-avec-les-scripts-shell-bash.txt · Dernière modification: 20/08/2022 08:35 par paskal

Pied de page des forums

Propulsé par FluxBB