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 [10/07/2014 12:22] Hypathie [Création, suppression, exportation de variables] |
doc:programmation:shells:script-bash-variables-arguments-parametres [15/10/2015 18:13] milou [Script bash : variables, arguments, paramètres] |
||
---|---|---|---|
Ligne 1: | Ligne 1: | ||
======Script bash : variables, arguments, paramètres ====== | ======Script bash : variables, arguments, paramètres ====== | ||
- | * Niveau requis : {{tag>débutant}} | + | * Objet : Script bash : variables, arguments, paramètres |
+ | * Niveau requis : {{tag>débutant avisé}} | ||
+ | * Commentaires : 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>à-placer}} | + | * Suivi : |
- | * Création par [[user>Hypathie]] 18/03/2014 | + | * Création par [[user>Hypathie]] le 18/03/2014 |
- | * Testé par <Hypathie> le <Juin 2014> | + | * Testé par [[user>Hypathie]] Juin 2014 |
* 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 !)) | * 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 !)) | ||
+ | Contributeurs, les FIXME sont là pour vous aider, supprimez-les une fois le problème corrigé ou le champ rempli ! | ||
+ | |||
+ | ------ | ||
- | * [[atelier:chantier:debuter-avec-les-scripts-shell-bash]] | + | **Nota : Les autres wiki :** |
+ | * [[doc:programmation:shells:debuter-avec-les-scripts-shell-bash | 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-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-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-etat-de-sorie-et-les-tests|script-bash-etat-de-sorie-et-les-tests]] | ||
- | * [[atelier:chantier:script-bash-les-tableaux|script-bash-les-tableaux]] | + | * [[doc:programmation:bash:script:tableaux|script-bash-les-tableaux]] |
- | * [[atelier:chantier:script-bash-les-fonctions|script-bash-les-fonctions]] | + | * [[doc:programmation:bash:script:fonction|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 ! | ||
Ligne 44: | Ligne 51: | ||
>La valeur ''ValeurDeLaVariable'' a été mémorisée. | >La valeur ''ValeurDeLaVariable'' a été mémorisée. | ||
- | ===$nom-de-la-variable=== | + | ===$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 : | 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 : | ||
Ligne 122: | Ligne 129: | ||
* 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 235: | Ligne 242: | ||
==== Suppression de variable : unset==== | ==== Suppression de variable : unset==== | ||
- | Soit le script "essai.sh" : passons à ce script l'argument "vous" | + | Soit le script "essai.sh" : passons à ce script l'argument ''vous'' |
<code bash> | <code bash> | ||
Ligne 479: | Ligne 486: | ||
=====Récupérer la longueur d'une valeur de variable===== | =====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}. | + | * Pour obtenir la longueur d'une chaîne stockée dans une variable, on écrit ''${#VAR}''. |
Exemples : | Exemples : | ||
Ligne 488: | Ligne 495: | ||
</code> | </code> | ||
- | * Pour récupérer la longueur d'un paramètre de position | + | * Pour récupérer la longueur d'un paramètre de position : |
FIXME | FIXME | ||
Ligne 494: | Ligne 501: | ||
=====Substitutions de commande===== | =====Substitutions de commande===== | ||
- | ====Utilisation ==== | + | ===Utilisation === |
Permet de se servir de la sortie d'une commande dans un autre contexte pour ; | Permet de se servir de la sortie d'une commande dans un autre contexte pour ; | ||
- affecter cette sortie à une variable ; | - affecter cette sortie à une variable ; | ||
Ligne 500: | Ligne 507: | ||
- etc. | - etc. | ||
- | ====deux syntaxes :==== | + | ===Deux syntaxes :=== |
<code> | <code> | ||
`commande` | `commande` | ||
Ligne 511: | Ligne 518: | ||
</code> | </code> | ||
- | ===$(cmd) : des exemples=== | + | ====Substitution simple : $(commande)==== |
<code bash> | <code bash> | ||
#!/bin/bash | #!/bin/bash | ||
Ligne 525: | Ligne 532: | ||
echo $(pwd ; ls) | echo $(pwd ; ls) | ||
</code> | </code> | ||
- | === $(cmd) : imbrication de commandes :=== | + | ====Imbrication de commandes : $(cmd $(cmd))==== |
<code bash> | <code bash> | ||
echo $( ls $(pwd)/Documents) | echo $( ls $(pwd)/Documents) | ||
</code> | </code> | ||
- | *avec set : | + | === Imbrication avec ''set'' === |
<code bash> | <code bash> | ||
#!/bin/bash | #!/bin/bash | ||
Ligne 549: | Ligne 556: | ||
====declare et typeset ==== | ====declare et typeset ==== | ||
- | ^ commandes ^options ^ | + | ^ commandes ^options ^ |
- | |declare/typeset |-r lecture seule | | + | |declare/typeset |''-r'' : lecture seule | |
- | |declare/typeset |-i entier | | + | |declare/typeset |''-i'' : entier | |
- | |declare/typeset |-a tableau (array) | | + | |declare/typeset |''-a'' tableau (array) | |
- | |declare/typeset |-f fonction(s) | | + | |declare/typeset |''-f'' : fonction(s) | |
- | |declare/typeset |-x export | | + | |declare/typeset |''-x'' : export | |
- | |declare/typeset |-x var=$value | | + | |declare/typeset |''-x'' : ''var=$valeur'' | |
Voir : [[http://abs.traduc.org/abs-5.1-fr/ch09s04.html|Guide avancé d'écriture des scripts Bash: 9.4. Typer des variables : declare ou typeset]] | Voir : [[http://abs.traduc.org/abs-5.1-fr/ch09s04.html|Guide avancé d'écriture des scripts Bash: 9.4. Typer des variables : declare ou typeset]] | ||
- | ===Remarques sur la commande declare -i et les calculs === | + | ===Remarques sur la commande "declare" et les calculs === |
<note important> | <note important> | ||
**Méthode non POSIX**\\ | **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] ... | + | * 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> | <code bash> | ||
Ligne 575: | Ligne 582: | ||
</code> | </code> | ||
- | * Pour que la valeur d'une variable ne soit pas accidentellement modifier, il faut ajouter l'attribut -r. | + | * Pour que la valeur d'une variable ne soit pas accidentellement modifier, il faut ajouter l'attribut ''-r''. |
<code bash> | <code bash> | ||
Ligne 583: | Ligne 590: | ||
echo $(($a+$b)) | echo $(($a+$b)) | ||
</code> | </code> | ||
- | retour | + | |
<code> | <code> | ||
80 | 80 | ||
</code> | </code> | ||
- | **Méthode POSIX : Les commandes let et ( ( ... ) ) permettent de typer les variables pour effectuer des calculs sur les variables (synonyme de declare -i).** | + | **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> | </note> | ||
Ligne 595: | Ligne 602: | ||
==== Les variables typées pour les calculs : let ou (( ... )) ==== | ==== 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]]** | + | Voir : [[atelier:chantier:page-man-bash-iv-symboles-dans-les-calculs-mathematiques?&#operateurs-arithmetiques|les opérateurs arithmétiques]] |
- | ===syntaxe=== | + | ===Syntaxe=== |
<code> | <code> | ||
let 'var = 5 + 5' | let 'var = 5 + 5' | ||
Ligne 602: | Ligne 609: | ||
$(( 5 * 3 )) | $(( 5 * 3 )) | ||
</code> | </code> | ||
- | === exemples=== | + | === Exemples=== |
<code bash> | <code bash> | ||
#!/bin/bash | #!/bin/bash | ||
Ligne 623: | Ligne 630: | ||
echo $(( $var2 % $var1 )) | echo $(( $var2 % $var1 )) | ||
</code> | </code> | ||
- | Retour | ||
<code> | <code> | ||
12 | 12 | ||
Ligne 636: | Ligne 642: | ||
==== L'affectation arthmétique==== | ==== L'affectation arthmétique==== | ||
- | **Voir [[atelier:chantier:page-man-bash-iv-symboles-dans-les-calculs-mathematiques?&#operateurs-d-affectation-arithmetique| les opérateurs d'affectation arithmétique]]** | + | 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 consiste à affecter à une variable le résultat d'un calcul arithmétique, par la **constante** (donc avec let) qu'on lui a donné.\\ | + | >cela permet de faire des incrémentation par autre chose que 1.) |
- | Soit une variable var de valeur x, si l'on fait **var +=2** alors la variable var sera **x + 2**.\\ | + | >Il en va de même pour les autres opérateurs.\\ |
- | (cela permet de faire des incrémentation par autre chose que 1 : voir plus incrémentation, décrémentation de la valeur 1 .)\\ | + | |
- | Il en va de même pour les autres opérateurs.\\ | + | |
- | === Exemples === | + | * Exemples |
<code bash> | <code bash> | ||
Ligne 661: | Ligne 668: | ||
</code> | </code> | ||
+ | ===Incrémentation, décrémentation=== | ||
- | ===incrémentation, décrémentation de la valeur 1 : ( ( var++ ) ) ; ( ( ++var ) ) ; ( ( var- - ) ), etc.=== | + | * incrémentation, décrémentation de la valeur 1 : ''<nowiki>(( var++ ))</nowiki>'' ; ''<nowiki>(( ++var ))</nowiki>'' ; ''<nowiki>(( var-- ))</nowiki>'', etc. |
<code bash> | <code bash> | ||
Ligne 691: | Ligne 699: | ||
done | done | ||
</code> | </code> | ||
- | [[atelier:chantier:script-bash-les-tableaux#se-creuser-un-peu-les-meninges|voir aussi ici]] | + | [[doc:programmation:bash:script:tableaux#se-creuser-un-peu-les-meninges|voir aussi ici]] |
* Ou encore de cette manière : | * Ou encore de cette manière : | ||
Ligne 701: | Ligne 709: | ||
====Changements de bases ==== | ====Changements de bases ==== | ||
Bash permet de changer de base (Il est par défaut en base 10)\\ | Bash permet de changer de base (Il est par défaut en base 10)\\ | ||
- | * base 8 (octal) : un chiffre précédé de **0**\\ | + | * base 8 (octal) : un chiffre n précédé de zéro : ''0n''\\ |
exemple : 02 => 2 en base 8 | exemple : 02 => 2 en base 8 | ||
- | * base 16(hexadécimal): un chiffre précédé de **0x**\\ | + | * base 16(hexadécimal): un chiffre n précédé de zéro+x : ''0xn''\\ |
exemple : 0x3 => 3 en base 16 | exemple : 0x3 => 3 en base 16 | ||
- | * autres bases : **base#nombre** | + | * autres bases : ''base#nombre'' |
* base maximale : base 64 | * base maximale : base 64 | ||