bash在单独的行上打印数组元素

时间:2013-03-28 20:53:48

标签: arrays bash

如何在单独的行上打印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

7 个答案:

答案 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[*]}"'