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:debuter-avec-les-scripts-shell-bash [03/06/2014 06:21] Hypathie [C ) Création de variables par l'utilisateur] |
doc:programmation:shells:debuter-avec-les-scripts-shell-bash [03/06/2014 10:25] Hypathie [C ) Création de variables] |
||
---|---|---|---|
Ligne 426: | Ligne 426: | ||
</note> | </note> | ||
- | ====3) Créer des variables avec les tableaux ==== | ||
- | 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]] | ||
- | ====4) création de variables quelques commandes à connaître==== | + | =====D ) Code de retour et les tests===== |
- | ===declare=== | + | ====1) le code de retour et la commande exit ==== |
- | ===let=== | + | |
- | =====D ) Les tests ==== | + | |
- | ====utiliser le code de retour : exit==== | + | |
+ | |||
+ | ====2 ) les tests ==== | ||
+ | ===À savoir :=== | ||
+ | |||
+ | * **[[atelier:chantier:la-page-man-bash-ii-les-operateurs-lexicographiques|les opérateurs lexicographiques]] et leur syntaxe** | ||
+ | * **[[atelier:chantier:page-man-bash-iii-les-operateurs-de-comparaison-numerique|les opérateurs de comparaison numérique et leur syntaxe]]** | ||
+ | * ** La commande test ou les crochets :[[atelier:chantier:page-man-bash-iii-les-operateurs-de-comparaison-numerique#conclusion-sur-les-operateurs-lexicographiques-et-les-operateurs-de-comparaison-numerique]]** | ||
+ | * **Attention au signe =** | ||
+ | Ne pas confondre le signe = de l'affectation d'une variable par une valeur (voir ci-dessus [[atelier:chantier:debuter-avec-les-scripts-shell-bash#affectation-directe|affectation directe]]) et l'opérateur de correspondance = (ou == ) utilisé dans les tests.\\ | ||
+ | Dans les tests sur les entiers l'égalité est représentée par l'option -eq ! | ||
+ | |||
+ | ===Avec la structure conditionnelle if === | ||
+ | **Voir[[doc:programmation:shell:avancee|Fonctionnalités avancées du Shell]] en particulier : [[doc:programmation:shell:avancee#instruction-conditionnelle-if|structure conditionnelle if]] pour ce qui suit** | ||
+ | |||
+ | <code bash> | ||
+ | #!/bin/bash | ||
+ | var1=23 | ||
+ | var2=36 | ||
+ | |||
+ | if [ $var1 -eq $var2 ] ; then | ||
+ | echo "$var1 et $var2 sont égales" | ||
+ | else | ||
+ | echo "$var1 et $var2 ne sont pas égales" | ||
+ | fi | ||
+ | |||
+ | if [ $var1 != $var2 ] ; then | ||
+ | echo "$var1 et $var2 sont inégales" | ||
+ | fi | ||
+ | |||
+ | if [ ${#var1} = ${#var2} ] ; then | ||
+ | echo "$var1 et $var2 sont des chaînes de même longueur" | ||
+ | fi | ||
+ | echo "les longueurs sont de : ${#var1} et de : ${#var2}" | ||
+ | </code> | ||
+ | |||
+ | ===composition avec les tests et valeur vide, valeur nulle=== | ||
+ | |||
+ | De même que la composition de commandes vu plus haut, on se sert de la composition avec les tests. Et oui les doubles crochets et la commande test sont des commandes ! LOL | ||
+ | |||
+ | * séquentielle : cmd1 ; cmd2 | ||
+ | * parallèle : cmd1 & cmd2 | ||
+ | * sur erreur (ou) : cmd1 || cmd2 | ||
+ | * sur succès (et) : cmd1 && cmd2 | ||
+ | |||
+ | * rappel des options des commandes de test : | ||
+ | - -z $chaine : teste si la variable ne contient rien | ||
+ | - -n $chaine : teste si la variable contient quelque-chose | ||
+ | |||
+ | <code bash> | ||
+ | #!/bin/bash | ||
+ | #var3 est nulle, non déclarée, (ou non initialisée) : sa valeur est nulle | ||
+ | #var2 est initialisée mais sans valeur : sa une valeur vide | ||
+ | var1=ma_variable | ||
+ | var2= | ||
+ | var2bis=" " | ||
+ | |||
+ | [ ${var1} ] && echo "$var1" # => ma_variable | ||
+ | [ -n ${var1} ] && echo "$var1" # => ma_variable | ||
+ | [ -n $var1 ] && echo "$var1" # => ma_variable | ||
+ | #ou encore : | ||
+ | test $var1 && echo "ok" # => ok | ||
+ | test -n $var1 && echo "ok var1 contient quelque-chose" # => ok var1 contient quelque-chose | ||
+ | test -z $var1 || echo "NON: var1 ne contient pas rien" # => NON: var1 ne contient pas rien | ||
+ | echo " " | ||
+ | |||
+ | [ -z $var2 ] && echo "var2: ${#var2} a une valeur vide : ne contient rien" # => var2: 0 a une valeur vide : ne contient rien | ||
+ | [ -n $var2 ] && echo "var2: une valeur vide contient 0 : du vide !" # => var2: une valeur vide contient 0 : du vide ! | ||
+ | [ -z $var2bis ] && echo "var2bis: comme var2" # => var2bis: comme var2 | ||
+ | [ -n $var2bis ] && echo "var2bis: comme var2" # => var2bis: comme var2 | ||
+ | echo " " | ||
+ | [ -n $var3 ] && echo "ET avec -n: une variable nulle contient aussi du vide" # => ET avec -n: une variable nulle contient aussi du vide | ||
+ | [ -n $var3 ] || echo "OU avec -n" # PAS DE RETOUR puisque la première commande a renvoyé le code de retour 0. | ||
+ | [ -z $var3 ] && echo " OU avec -z une variable nulle contient aussi du vide" # => OU avec -z une variable nulle contient aussi du vide | ||
+ | [ -z $var3 ] || echo " OU avec -z" # PAS DE RETOUR puisque la première commande a renvoyé le code de retour 0. | ||
+ | </code> | ||
+ | |||
+ | ===Alternatives : case=== | ||
+ | ** Attention case n'utilise pas d'expression régulière mais du "pattern matching" | ||
+ | |||
+ | * syntaxe de case : | ||
+ | <code bash> | ||
+ | case $variable in | ||
+ | expression) | ||
+ | instructions | ||
+ | ;; | ||
+ | ... | ||
+ | esac | ||
+ | </code> | ||
+ | * explications : | ||
+ | - case "teste" la valeur du paramètre passé au script avec chaque "expression" ; | ||
+ | - et en fonction du test il y a exécution ou pas des commandes placées au niveau de "instructions" ; | ||
+ | - Case sert à conditionner l'exécution des commandes en fonction d'argument choisi ; | ||
+ | - On se sert de "l'étoile" pour permettre que soit exécuter quelque chose quand n'importe quel autre paramètre que ceux des expressions, est passé au script; | ||
+ | * Ne pas oublier : | ||
+ | - le double point virgule qui permet de clôturer chaque test ; | ||
+ | - esac pour finir. | ||
+ | * exemple : | ||
+ | <code bash> | ||
+ | #!/bin/bash | ||
+ | # passer le paramètre 'coco' à ce script ; puis 'cucu' ; titi puis toto, puis celui que voulez. | ||
+ | case $1 in | ||
+ | coco) | ||
+ | echo "Vous avez passé le paramètre 'coco', ré-essayez avec 'cucu'" | ||
+ | ;; | ||
+ | cucu) | ||
+ | echo "Vous avez passé le paramètre 'cucu'" | ||
+ | echo "un peu d'humour !" | ||
+ | echo "Ré-essayé un paramètre de votre choix." | ||
+ | ;; | ||
+ | titi|toto) | ||
+ | echo "vous avez passé le paramètre $1" | ||
+ | ;; | ||
+ | *) | ||
+ | echo "Vous avez choisi $1" | ||
+ | esac | ||
+ | </code> | ||
+ | |||
+ | Vous avez tout en mains pour comprendre ceci : [[doc:programmation:shell:avancee#selecteur-case|Fonctionnalités avancées du Shell: selecteur-case]] | ||
=====E ) Valeurs d'une variable internes ou externes à un script===== | =====E ) Valeurs d'une variable internes ou externes à un script===== |