arrays - élément - tableau shell




Boucle à travers un tableau de chaînes dans Bash? (11)

Je veux écrire un script qui boucle à travers 15 chaînes (tableau possible?) Est-ce possible?

Quelque chose comme:

for databaseName in listOfNames
then
  # Do something
end

Tableau implicite pour le script ou les fonctions:

En plus de la bonne réponse d' anubhava : Si la syntaxe de base pour la boucle est:

for var in "${arr[@]}" ;do ...$var... ;done

il y a un cas particulier dans bash :

Lors de l'exécution d'un script ou d'une fonction, les arguments passés sur les lignes de commande sont affectés à la variable [email protected] array, vous pouvez y accéder par $1 , $2 , $3 , etc.

Cela peut être rempli (pour le test) par

set -- arg1 arg2 arg3 ...

Une boucle sur ce tableau pourrait être écrite simplement:

for item ;do
    echo "This is item: $item."
  done

Notez que le travail réservé in n'est pas présent et pas de nom de tableau aussi!

Échantillon:

set -- arg1 arg2 arg3 ...
for item ;do
    echo "This is item: $item."
  done
This is item: arg1.
This is item: arg2.
This is item: arg3.
This is item: ....

Notez que c'est la même chose que

for item in "[email protected]";do
    echo "This is item: $item."
  done

Puis dans un script :

#!/bin/bash

for item ;do
    printf "Doing something with '%s'.\n" "$item"
  done

Sauvegardez ceci dans un script myscript.sh , chmod +x myscript.sh , puis

./myscript.sh arg1 arg2 arg3 ...
Doing something with 'arg1'.
Doing something with 'arg2'.
Doing something with 'arg3'.
Doing something with '...'.

Pareil dans une fonction :

myfunc() { for item;do cat <<<"Working about '$item'."; done ; }

alors

myfunc item1 tiem2 time3
Working about 'item1'.
Working about 'tiem2'.
Working about 'time3'.

Aucune de ces réponses ne comprend un compteur ...

#!/bin/bash
## declare an array variable
declare -a array=("one" "two" "three")

# get length of an array
arraylength=${#array[@]}

# use for loop to read all values and indexes
for (( i=1; i<${arraylength}+1; i++ ));
do
  echo $i " / " ${arraylength} " : " ${array[$i-1]}
done

Sortie:

1  /  3  :  one
2  /  3  :  two
3  /  3  :  three

C'est aussi facile à lire:

FilePath=(
    "/tmp/path1/"    #FilePath[0]
    "/tmp/path2/"    #FilePath[1]
)

#Loop
for Path in "${FilePath[@]}"
do
    echo "$Path"
done

C'est possible, bien sûr.

for databaseName in a b c d e f; do
  # do something like: echo $databaseName
done 

Voir Bash Loops pour, while et until pour plus de détails.


Dans le même esprit que la réponse de 4ndrew:

listOfNames="RA
RB
R C
RD"

# To allow for other whitespace in the string:
# 1. add double quotes around the list variable, or
# 2. see the IFS note (under 'Side Notes')

for databaseName in "$listOfNames"   #  <-- Note: Added "" quotes.
do
  echo "$databaseName"  # (i.e. do action / processing of $databaseName here...)
done

# Outputs
# RA
# RB
# R C
# RD

B. Pas d'espace dans les noms:

listOfNames="RA
RB
R C
RD"

for databaseName in $listOfNames  # Note: No quotes
do
  echo "$databaseName"  # (i.e. do action / processing of $databaseName here...)
done

# Outputs
# RA
# RB
# R
# C
# RD

Remarques

  1. Dans le second exemple, l'utilisation de listOfNames="RA RB RC RD" a la même sortie.

D'autres façons d'apporter des données comprennent:

  • stdin (énuméré ci-dessous),
  • variables ,
  • un tableau (la réponse acceptée),
  • un fichier ...

Lire depuis stdin

# line delimited (each databaseName is stored on a line)
while read databaseName
do
  echo "$databaseName"  # i.e. do action / processing of $databaseName here...
done # <<< or_another_input_method_here
  1. le séparateur de champ de bash IFS "à la ligne" [ 1 ] délimiteur peut être spécifié dans le script pour permettre d'autres espaces (ie IFS='\n' , ou pour MacOS IFS='\r' )
  2. J'aime la réponse acceptée aussi :) - J'ai inclus ces extraits comme d'autres moyens utiles qui répondent également à la question.
  3. Y compris #!/bin/bash en haut du fichier de script indique l'environnement d'exécution.
  4. Il m'a fallu des mois pour comprendre comment coder cela simplement :)

Autres sources ( en boucle de lecture )


Essaye ça. Cela fonctionne et testé.

for k in "${array[@]}"
do
    echo $k
done

# For accessing with the echo command: echo ${array[0]}, ${array[1]}

Le tableau declare ne fonctionne pas pour Korn shell. Utilisez l'exemple ci-dessous pour le shell Korn:

promote_sla_chk_lst="cdi xlob"

set -A promote_arry $promote_sla_chk_lst

for i in ${promote_arry[*]};
    do
            echo $i
    done

Première ligne possible de chaque script / session Bash:

say() { for line in "${@}" ; do printf "%s\n" "${line}" ; done ; }

Utilisez par exemple:

$ aa=( 7 -4 -e ) ; say "${aa[@]}"
7
-4
-e

Peut considérer: echo interprets -e comme option ici


Vous pouvez l'utiliser comme ceci:

## declare an array variable
declare -a arr=("element1" "element2" "element3")

## now loop through the above array
for i in "${arr[@]}"
do
   echo "$i"
   # or do whatever with individual element of the array
done

# You can access them using echo "${arr[0]}", "${arr[1]}" also

Fonctionne également pour la déclaration de tableau multiligne

declare -a arr=("element1" 
                "element2" "element3"
                "element4"
                )

Vous pouvez utiliser la syntaxe de ${arrayName[@]}

#!/bin/bash
# declare an array called files, that contains 3 values
files=( "/etc/passwd" "/etc/group" "/etc/hosts" )
for i in "${files[@]}"
do
    echo "$i"
done

listOfNames="db_one db_two db_three"
for databaseName in $listOfNames
do
  echo $databaseName
done

ou juste

for databaseName in db_one db_two db_three
do
  echo $databaseName
done






unix