Réponses:
Voici un moyen qui utilise l’extension du paramètre bash et sa IFS
variable spéciale.
$ System=('s1' 's2' 's3' 's4 4 4')
$ ( IFS=$'\n'; echo "${System[*]}" )
Nous utilisons un sous-shell pour éviter d'écraser la valeur de IFS
dans l'environnement actuel. Dans ce sous-shell, nous modifions ensuite la valeur de IFS
afin que le premier caractère soit une nouvelle ligne (en utilisant des $'...'
guillemets). Enfin, nous utilisons les paramètres de développement pour imprimer le contenu du tableau sous la forme d’un mot unique; chaque élément est séparé par le premier caractère de IFS
.
Pour capturer une variable:
$ var=$( IFS=$'\n'; echo "${System[*]}" )
Si votre bash est suffisamment nouveau (4.2 ou ultérieur), vous pouvez (et devriez) toujours utiliser printf
avec l' -v
option:
$ printf -v var "%s\n" "${System[@]}"
Dans les deux cas, vous ne voudrez peut-être pas la nouvelle ligne finale var
. Pour l'enlever:
$ var=${var%?} # Remove the final character of var
var=${var%?}
place? Ce n'est pas une expression régulière et .
ne correspondra donc qu'à un point.
$ IFS=', ' $ echo ${VAR[*]} first second third $ echo "${VAR[*]}" first,second,third
awk -v sep='\n' 'BEGIN{ORS=OFS="";for(i=1;i<ARGC;i++){print ARGV[i],ARGC-i-1?sep:""}}' "${arr[@]}"
ou
perl -le 'print join "\n",@ARGV' "${arr[@]}"
ou
python -c 'import sys;print "\n".join(sys.argv[1:])' "${arr[@]}"
ou
sh -c 'IFS=$'\''\n'\'';echo "$*"' '' "${arr[@]}"
ou
lua <(echo 'print(table.concat(arg,"\n"))') "${arr[@]}"
ou
tclsh <(echo 'puts [join $argv "\n"]') "${arr[@]}"
ou
php -r 'echo implode("\n",array_slice($argv,1));' -- "${arr[@]}"
ou
ruby -e 'puts ARGV.join("\n")' "${arr[@]}"
c'est tout ce que je peux rappeler jusqu'à présent.
Les solutions ci-dessus sont à peu près ce qu'elles sont, mais la question initiale demande une sortie dans un fichier:
$ a=(a b c d e)
$ ( IFS=$'\n'; echo "${a[*]}" ) > /tmp/file
$ cat /tmp/file
a
b
c
d
e
$
Notes: 1) 'echo' fournit la nouvelle ligne finale. 2) Si bash veut à nouveau lire ce fichier, bas, alors -p peut être la sérialisation désirée.
Utilisant pour :
for each in "${alpha[@]}"
do
echo "$each"
done
Utiliser l' histoire ; notez que cela échouera si vos valeurs contiennent !
:
history -p "${alpha[@]}"
Utiliser le nom de base ; notez que cela échouera si vos valeurs contiennent /
:
basename -a "${alpha[@]}"
En utilisant shuf ; notez que les résultats risquent de ne pas apparaître dans l'ordre:
shuf -e "${alpha[@]}"
Ma prise , en utilisant uniquement les commandes intégrées de Bash, sans mutation IFS
:
# $1 separator
# $2… strings
join_strings () {
declare separator="$1";
declare -a args=("${@:2}");
declare result;
printf -v result '%s' "${args[@]/#/$separator}";
printf '%s' "${result:${#separator}}"
}
$ join_strings $'\n' "a b c" "d e f" "g h i"
a b c
d e f
g h i
Vous pouvez également utiliser n'importe quel séparateur:
$ join_strings '===' "a b c" "d e f" "g h i"
a b c===d e f===g h i
printf
semble être l’approche la plus efficace pour créer une chaîne délimitée à partir d’un tableau:
# create a delimited string; note that printf doesn't put the trailing delimiter
# need to save and restore IFS
# it is prudent to put the whole logic on a single line so as to minimize the risk of future code changes breaking the sequence of saving/restoring of IFS
oldIFS=$IFS; IFS=$'\n'; printf -v var "${arr[*]}"; IFS=$oldIFS
# print string to file; note that the newline is required in the format string because printf wouldn't put a trailing delimiter (which is a good thing)
printf '%s\n' "$var" > file
Une façon encore plus simple de faire ceci est:
delim=$'\n'
printf -v var "%s$delim" "${arr[@]}" # create a delimited string
var="${var%$delim}" # remove the trailing delimiter
delim=:
arr=(one two three)
printf -v var "%s$delim" "${arr[@]}" # yields one:two:three:
var="${var%$delim}" # yields one:two_three