如何在单独的行上打印Bash数组的数组元素?这个有用,但肯定有更好的方法:
$ my_array=(one two three)
$ for i in ${my_array[@]}; do echo $i; done
one
two
three
试过这个,但它不起作用:
$ IFS=$'\n' echo ${my_array[*]}
one two three
答案 0 :(得分:349)
尝试这样做:
$ printf '%s\n' "${my_array[@]}"
$@
和$*
之间的差异:
未引用,结果未指定。在Bash中,两者都扩展为单独的args 然后是wordsplit和globbed。
引用,"$@"
将每个元素展开为单独的参数,而"$*"
扩展到args合并为一个参数:"$1c$2c..."
(其中c
是。IFS
"$@"
)的第一个字符。
你几乎总是想要"${arr[@]}"
。同样适用于{{1}}。
始终引用它们!
答案 1 :(得分:61)
只需引用echo的参数:
( IFS=$'\n'; echo "${my_array[*]}" )
子shell有助于在使用后恢复IFS
答案 2 :(得分:29)
使用代替:
for each in "${alpha[@]}"
do
echo "$each"
done
使用历史记录;请注意,如果您的值包含!
:
history -p "${alpha[@]}"
使用 basename ;请注意,如果您的值包含/
:
basename -a "${alpha[@]}"
使用 shuf ;请注意,结果可能不会按顺序排出:
shuf -e "${alpha[@]}"
答案 3 :(得分:3)
我在这里尝试了一个巨大的答案......如果循环,但没有得到任何快乐 - 所以我这样做了,也许是凌乱但做了工作:
# EXP_LIST2 is iterated
# imagine a for loop
EXP_LIST="List item"
EXP_LIST2="$EXP_LIST2 \n $EXP_LIST"
done
echo -e $EXP_LIST2
虽然这给列表添加了一个空格,这很好 - 我希望它缩进一点。 还假设“\ n”可以打印在原始$ EP_LIST中。
答案 4 :(得分:3)
另一个有用的变体是管道tr
:
echo "${my_array[@]}" | tr ' ' '\n'
这看起来简单紧凑
答案 5 :(得分:0)
你可以使用 Bash C 风格的 For 循环来做你想做的事。
my_array=(one two three)
for ((i=0; i < ${#my_array[@]}; i++ )); do echo "${my_array[$i]}"; done
one
two
three
答案 6 :(得分:-1)
我发现您可以使用 eval 来避免使用子shell。因此:
IFS=$'\n' eval 'echo "${my_array[*]}"'