Kurt Stutsman在问题的注释中提供了正确的指针:使用Bash数组来解决您的问题.
这是一个简化的例子:
groups=() # declare an empty array; same as: declare -a groups
for i in {0..5}; do
groups[i]="group $i" # dynamically create element with index $i
done
# Print the resulting array's elements.
printf '%s\n' "${groups[@]}"
有关枚举数组${groups [@]}元素的其他方法,请参阅本答案的底部.
> bash数组可以动态扩展(甚至可以是稀疏的 – 元素索引不需要是连续的)
>因此,只需分配元素$i就可以工作,而无需事先确定数组的大小.
>注意$i不需要在数组下标中以$为前缀,因为数组下标是在算术上下文中计算的(在评估$((…))表达式的相同上下文中).
至于你做错了什么:
group$i=...
不被Bash识别为变量赋值,因为 – 字面意思 – group $i不是有效的标识符(变量名).
因为它不是,Bash继续解析,直到找到下一个shell元字符,然后将生成的单词解释为执行命令,在您的情况下导致错误消息group0 = j:找不到命令.
如果由于某种原因,您不想使用数组来完全避免此问题,则可以解决此问题:
通过涉及变量声明的内置[命令],例如声明,本地或导出,您可以强制Bash首先执行扩展,这会将组$i扩展为有效的变量名称,然后再将其传递给内置函数.
> user2683246’s answer演示了使用declare(或者,如果需要函数内的局部变量,本地)来创建变量的下一个最佳方法.
> Soren’s answer使用export,但仅当您想要创建子进程可见的环境变量而不仅仅是shell变量时,才建议使用export.
警告:使用这种技术,一定要加倍引用RHS以获取全部价值;为了显示:
i=0; declare v$i=$(echo 'hi, there'); echo "$v0" # !! WRONG -> 'hi,': only UP TO 1ST SPACE
i=0; declare v$i="$(echo 'hi, there')"; echo "$v0" # OK -> 'hi, there'
枚举上面创建的groups数组的其他方法:
# Enumerate array elements directly.
for element in "${groups[@]}"; do
echo "$element"
done
# Enumerate array elements by index.
for (( i = 0; i < ${#groups[@]}; i++ )); do
echo "#$i: ${groups[i]}"
done