所以我的shell脚本看起来像这样:
VAR=$(shuf -i 1-10 -n 3)
N=1
while [$N le 3 ]; do
NUM=$VAR | awk '{print$`echo $N`}'
#some commands that uses $NUM
N=$(($N+1))
done
但我认为awk
在这里不起作用,因为
echo $VAR | awk '{print$`echo $N`}'
给了我
awk: cmd. line:1: {print$`echo $N`}
awk: cmd. line:1: ^ invalid char '`' in expression
awk: cmd. line:1: {print$`echo $N`}
awk: cmd. line:1: ^ syntax error
所以我尝试了以下命令
echo $VAR | awk '{print$$(echo $N)}'
这次我总是看到所有三个值,无论$N
是什么
我还可以尝试其他命令吗?
答案 0 :(得分:3)
bash
构造对空间非常敏感,[$N le 3 ]
中的简单遗漏空间需要写为[ $N le 3 ]
var=$(..)
,其中$(..)
包含要运行的命令。$(..))
内运行命令替换(后退或awk
。请记住awk
不是 shell。您不能&# 39;需要使用awk
或任何第三方工具来迭代数组,只需使用shell内部。由于shuf
以新行打印输出。使用工具mapfile
/ readarray
将项目安全地存储到数组中,即
mapfile -t randomElements < <(shuf -i 1-10 -n 3)
<()
是bash
中称为进程替换的特殊构造,进程的输出(在您的情况下为shuf
)显示为要读取的临时文件。
我们现在使用循环迭代元素
for ((i=0; i<"${#randomElements[@]}"; i++)); do
printf '%s\n' "${randomElements[i]}"
done
如果偶然mapfile
/ readarray
bash
版本中的read
版本不存在,请使用while IFS= read -r line; do arr+=("$line"); done < <(shuf -i 1-10 -n 3)
命令
{{1}}
并像往常一样使用打印逻辑。