Truco simple de una línea para volcar la matriz
He agregado un valor con espacios:
foo=()
foo[12]="bar"
foo[42]="foo bar baz"
foo[35]="baz"
Yo, para volcar rápidamente intentomatrices o matrices asociativas que uso
Este comando de una línea:
paste <(printf "%s\n" "${!foo[@]}") <(printf "%s\n" "${foo[@]}")
Rendirá:
12 bar
35 baz
42 foo bar baz
Explicado
printf "%s\n" "${!foo[@]}"
imprimirá todas las teclas separadas por una nueva línea ,
printf "%s\n" "${foo[@]}"
imprimirá todos los valores separados por una nueva línea ,
paste <(cmd1) <(cmd2)
fusionará la salida de cmd1
y cmd2
línea por línea.
Tunning
Esto podría ajustarse mediante el -d
interruptor:
paste -d : <(printf "%s\n" "${!foo[@]}") <(printf "%s\n" "${foo[@]}")
12:bar
35:baz
42:foo bar baz
o incluso:
paste -d = <(printf "foo[%s]\n" "${!foo[@]}") <(printf "'%s'\n" "${foo[@]}")
foo[12]='bar'
foo[35]='baz'
foo[42]='foo bar baz'
La matriz asociativa funcionará igual:
declare -A bar=([foo]=snoopy [bar]=nice [baz]=cool [foo bar]='Hello world!')
paste -d = <(printf "bar[%s]\n" "${!bar[@]}") <(printf '"%s"\n' "${bar[@]}")
bar[foo bar]="Hello world!"
bar[foo]="snoopy"
bar[bar]="nice"
bar[baz]="cool"
Problema con líneas nuevas o caracteres especiales
Desafortunadamente, hay al menos una condición que hace que esto ya no funcione: cuando la variable contiene nueva línea:
foo[17]=$'There is one\nnewline'
El comando paste
se fusionará línea por línea, por lo que la salida se volverá incorrecta:
paste -d = <(printf "foo[%s]\n" "${!foo[@]}") <(printf "'%s'\n" "${foo[@]}")
foo[12]='bar'
foo[17]='There is one
foo[35]=newline'
foo[42]='baz'
='foo bar baz'
Para este trabajo, puede usar en %q
lugar del %s
segundo printf
comando (y comillas):
paste -d = <(printf "foo[%s]\n" "${!foo[@]}") <(printf "%q\n" "${foo[@]}")
Se hará perfecto:
foo[12]=bar
foo[17]=$'There is one\nnewline'
foo[35]=baz
foo[42]=foo\ bar\ baz
De man bash
:
%q causes printf to output the corresponding argument in a
format that can be reused as shell input.
(a b c)
para convertirlo en una matriz.