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-enchainement-de-commandes-et-etat-de-sortie [06/06/2014 08:27] Hypathie [Enchaînements de commandes dans les scripts] |
doc:programmation:shells:script-bash-enchainement-de-commandes-et-etat-de-sortie [07/06/2014 09:20] Hypathie [Redirections et le pipe] |
||
---|---|---|---|
Ligne 6: | Ligne 6: | ||
* Création par **Hypathie** 18/03/2014 | * Création par **Hypathie** 18/03/2014 | ||
* Testé par <Hypathie> le <Juin 2014> | * 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 !)) | + | * 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 : wiki n°4**\\ | **Nota : wiki n°4**\\ | ||
Ligne 12: | Ligne 12: | ||
* wiki n°1 : [[atelier:chantier:debuter-avec-les-scripts-shell-bash]] | * wiki n°1 : [[atelier:chantier:debuter-avec-les-scripts-shell-bash]] | ||
* wiki n°2 : [[atelier:chantier:script-bash-variables-arguments-parametres|script-bash-variables-arguments-parametres]] | * wiki n°2 : [[atelier:chantier:script-bash-variables-arguments-parametres|script-bash-variables-arguments-parametres]] | ||
- | * wiki n°3 : [[atelier:chantier:script-bash-detail-sur-les-parametres-et-les-boucles|script-bash-detail-sur-les-parametres]] | + | * wiki n°3 : [[atelier:chantier:script-bash-detail-sur-les-parametres-et-les-boucles|modification de variable et de paramètre]] |
| | ||
* wiki n°5 : [[atelier:chantier:script-bash-etat-de-sorie-et-les-tests|script-bash-etat-de-sorie-et-les-tests]] | * wiki n°5 : [[atelier:chantier:script-bash-etat-de-sorie-et-les-tests|script-bash-etat-de-sorie-et-les-tests]] | ||
Ligne 107: | Ligne 107: | ||
</code> | </code> | ||
Voir : [[http://abs.traduc.org/abs-fr/ch21.html|Guide avancé d'écriture des scripts Bash: 21. Sous-shells]] | Voir : [[http://abs.traduc.org/abs-fr/ch21.html|Guide avancé d'écriture des scripts Bash: 21. Sous-shells]] | ||
+ | |||
+ | <note tip> | ||
+ | On ne confondra plus ! | ||
+ | <code bash> | ||
+ | #!/bin/bash | ||
+ | { var1=yep ;} | ||
+ | echo $var1 | ||
+ | var3=coucou | ||
+ | { var4=yep ; $var4 ;} | ||
+ | echo $var3 | ||
+ | </code> | ||
+ | retour : | ||
+ | <code> | ||
+ | yep | ||
+ | essai.sh: ligne5: yep : commande introuvable | ||
+ | coucou | ||
+ | </code> | ||
+ | |||
+ | Mais : | ||
+ | <code bash> | ||
+ | #!/bin/bash | ||
+ | var1=coucou | ||
+ | (var2=yep ) | ||
+ | echo $var1 $var2 | ||
+ | ( var3="au revoir" ; echo $var3 ) | ||
+ | </code> | ||
+ | retour : | ||
+ | <code> | ||
+ | coucou | ||
+ | au revoir | ||
+ | </code> | ||
+ | </note> | ||
====Notion de sous-shell ==== | ====Notion de sous-shell ==== | ||
Ligne 114: | Ligne 146: | ||
===Le processus père ne peut pas récupérer les variables d'un processus fils=== | ===Le processus père ne peut pas récupérer les variables d'un processus fils=== | ||
- | [code bash] | + | |
+ | <code bash> | ||
#!/bin/bash | #!/bin/bash | ||
nom=nenette | nom=nenette | ||
( prenom=hypathie ) | ( prenom=hypathie ) | ||
echo $nom $prenom | echo $nom $prenom | ||
- | [/code] | + | </code> |
Retour : | Retour : | ||
Ligne 128: | Ligne 162: | ||
===Lancer deux sous-shell en parallèle === | ===Lancer deux sous-shell en parallèle === | ||
Il est possible de lancer deux processus en parallèle. | Il est possible de lancer deux processus en parallèle. | ||
- | + | Comparez le retour des lignes n°2 et n°3 avec celles des lignes n°5 et n°6 du code ci-dessous. | |
- | [code bash] | + | <code bash> |
#!/bin/bash | #!/bin/bash | ||
( echo "bonjour" ) & ( echo "au revoir" ) | ( echo "bonjour" ) & ( echo "au revoir" ) | ||
Ligne 136: | Ligne 170: | ||
cd /etc/apt ; ls | cd /etc/apt ; ls | ||
cd /etc/calendar ; ls | cd /etc/calendar ; ls | ||
- | [/code] | + | </code> |
- | Comparez le retour. | + | |
====Le shell restreint ==== | ====Le shell restreint ==== | ||
Ligne 160: | Ligne 194: | ||
* $SHELLOPTS : où on peut changer les options d'environnement du shell | * $SHELLOPTS : où on peut changer les options d'environnement du shell | ||
* et les droits sont limités. | * et les droits sont limités. | ||
- | =====Redirections et le pipe dans les scripts===== | + | =====Redirections et le pipe ===== |
- | * À voir : | + | * Liste des opératieurs : [[atelier:chantier:bash-les-differents-caracteres-speciaux#les-operateurs-de-redirection|un tableau des opérateurs de redirection]] |
- | * [[atelier:chantier:bash-les-differents-caracteres-speciaux#les-operateurs-de-redirection|un tableau des opérateurs de redirection]] | + | * Exercices dans le terminal, tout est là : [[doc:programmation:shell:chevrons| les chevrons]] |
- | ====Rappels :==== | + | |
+ | ==== Redirections : quelques points importants pour les scripts==== | ||
+ | ===Rappels sur les flux === | ||
Les redirections permettent de travailler non pas en se servant du code de retour (qui indique la réussite ou l'échec de l'exécution d'une commande) mais sur les flux.\\ | Les redirections permettent de travailler non pas en se servant du code de retour (qui indique la réussite ou l'échec de l'exécution d'une commande) mais sur les flux.\\ | ||
Un processus unix possède (par défaut) trois voies d'interaction entre le système et l'utilisateur. Une entrée et deux sorties. Chacun de ces "lieux" sont identifiés par un descripteur de fichier. | Un processus unix possède (par défaut) trois voies d'interaction entre le système et l'utilisateur. Une entrée et deux sorties. Chacun de ces "lieux" sont identifiés par un descripteur de fichier. | ||
Ligne 179: | Ligne 214: | ||
le fichier quand il existe et que l'option noclobber (-c) est activée. | le fichier quand il existe et que l'option noclobber (-c) est activée. | ||
</code> | </code> | ||
- | ====Opérateurs de sortie et opérateurs d'entrée ==== | ||
- | * Tout est là : [[doc:programmation:shell:chevrons| les chevrons]] \\ | ||
- | ===Opérateurs de sortie dans un script :=== | + | ===Utilisation de la sortie d'erreur dans les scripts=== |
- | + | ||
- | <code bash> | + | |
- | #!/bin/bash | + | |
- | # mise en place : | + | |
- | { mkdir ~/ABCD ; cd ABCD ; touch a b c d ; cd ~ ; pwd ;} | + | |
- | + | ||
- | # création de fichier avec " > " : | + | |
- | cd ~/ABCD && > fichier1 && pwd ; cd ~ && pwd && > /home/hypathie/ABCD/fichier2 && pwd && cd ~ && pwd | + | |
- | # espace facultatif avant et après " > " | + | |
- | + | ||
- | # redirection de la sortie de commande vers un fichier : | + | |
- | ls>/home/hypathie/ABCD/recup-ls # espace facultatif avant et après " > " | + | |
- | </code> | + | |
- | + | ||
- | Retour : | + | |
- | <code bash> | + | |
- | /home/hypathie # après cd ~ on est retourné dans le répertoire de l'utilisateur | + | |
- | /home/hypathie/ABCD # après création du fichier1 on est encore dans "ABCD" | + | |
- | /home/hypathie # après cd ~ on est retourné dans le répertoire utilisateur | + | |
- | /home/hypathie # on a créé fichier2 dans "ABCD" depuis le répertoire utilisateur | + | |
- | /home/hypathie | + | |
- | </code> | + | |
- | <note important> | + | |
- | Attention: | + | |
- | Créer un fichier avec > est un bashisme. La méthode universelle est d'utiliser "touch". | + | |
- | Amateurs de magie blanche et noire voir ce fil : [[http://debian-facile.org/viewtopic.php?pid=86634#p86634]] | + | |
- | </note> | + | |
- | + | ||
- | ===Opérateurs d'entrée dans les scripts=== | + | |
- | + | ||
- | <code bash> | + | |
- | < Place, en entrée d'une commande, un contenu. | + | |
- | </code> | + | |
- | <code bash> | + | |
- | cat < /chemin/du/fichier.txt # est un équivalent de cat /chemin/du/fichier.txt | + | |
- | </code> | + | |
- | <code bash> | + | |
- | << Redirige en entrée une série de données. | + | |
- | </code> | + | |
- | On nomme cette redirection "label".\\ Redirection utilisée dans un document en ligne dont on se sert que pour certaines commandes, comme ftp ou cat.\\ Voir : [[http://abs.traduc.org/abs-5.0-fr/ch18.html#heredocref]]\\ | + | |
- | Ne pas confondre avec la commande e2label, voir : [[doc:systeme:e2label]] | + | |
- | + | ||
- | ===Usages de la sortie d'erreur dans les scripts=== | + | |
* La sortie standard d'erreur peut être dirigée vers un fichier en le créant ou en l'écrasant : | * La sortie standard d'erreur peut être dirigée vers un fichier en le créant ou en l'écrasant : | ||
Ligne 282: | Ligne 272: | ||
</code> | </code> | ||
+ | ===Utilisation du "text processing" === | ||
+ | * Tout est là : [[http://wiki.debian-facile.org/atelier:chantier:les-commandes-join-paste-split-et-nl|http://wiki.debian-facile.org/atelier:chantier:les-commandes-join-paste-split-et-nl]] | ||
- | ====Un petit exercice sur opérateurs ==== | + | ====Un petit exercice sur opérateurs d'enchaînement et de redirection==== |
+ | ===énoncé=== | ||
Écrire un script qui crée le dossier "ABCD" et 4 fichiers vides (nommés a b c d) ; | Écrire un script qui crée le dossier "ABCD" et 4 fichiers vides (nommés a b c d) ; | ||
qui liste le contenu de "ABCD" et qui inscrit le résultat dans un fichier nommé "ls1" qui sera placé dans "ABCD" ; | qui liste le contenu de "ABCD" et qui inscrit le résultat dans un fichier nommé "ls1" qui sera placé dans "ABCD" ; | ||
Ligne 290: | Ligne 283: | ||
puis une deuxième ligne de texte dans "fichier.txt", en affichant dans le terminal,\\ le nombre de lignes, de mots et d'octets que possède le fichier "fichier.txt" ; | puis une deuxième ligne de texte dans "fichier.txt", en affichant dans le terminal,\\ le nombre de lignes, de mots et d'octets que possède le fichier "fichier.txt" ; | ||
se servir de différentes méthodes tout au long du script pour vérifier\\ au niveau du terminal que chaque commande s'est bien déroulée. | se servir de différentes méthodes tout au long du script pour vérifier\\ au niveau du terminal que chaque commande s'est bien déroulée. | ||
+ | <note important> | ||
+ | Attention: | ||
+ | Créer un fichier avec > est un bashisme. La méthode universelle est d'utiliser "touch". | ||
+ | Amateurs de magie blanche et noire voir ce fil : [[http://debian-facile.org/viewtopic.php?pid=86634#p86634]] | ||
+ | </note> | ||
+ | ===une solution=== | ||
Bonne lecture ;-) | Bonne lecture ;-) | ||
<code bash> | <code bash> | ||
Ligne 317: | Ligne 315: | ||
echo $? ;} | echo $? ;} | ||
</code> | </code> | ||
- | Retour : | + | |
- | <code> | + | |
- | 0 | + | |
- | 0 | + | |
- | 0 | + | |
- | /home/hypathie | + | |
- | 0 | + | |
- | /home/hypathie | + | |
- | 0 | + | |
- | J'écris un script, | + | |
- | 0 | + | |
- | avec les opérateurs de redirection. | + | |
- | 0 | + | |
- | 2 8 57 | + | |
- | 0 | + | |
- | </code> | + | |
* **2>>/dev/null** : permet ici de relancer le script autant de fois qu'on veut, sans voir apparaître de message d'erreur : mkdir fichier-existant ne réinitialise pas un fichier de type dossier en le vidant. | * **2>>/dev/null** : permet ici de relancer le script autant de fois qu'on veut, sans voir apparaître de message d'erreur : mkdir fichier-existant ne réinitialise pas un fichier de type dossier en le vidant. |