我已经得到以下工作:
for i in {2..10}
do
echo "output: $i"
done
它产生了一系列的输出行:2,输出:3,等等。
然而,试图运行以下程序:
max=10
for i in {2..$max}
do
echo "$i"
done
产生以下结果:
output: {2..10}
我怎样才能让编译器意识到它应该把$max作为数组的另一端,而不是字符串的一部分?
我已经得到以下工作:
for i in {2..10}
do
echo "output: $i"
done
它产生了一系列的输出行:2,输出:3,等等。
然而,试图运行以下程序:
max=10
for i in {2..$max}
do
echo "$i"
done
产生以下结果:
output: {2..10}
我怎样才能让编译器意识到它应该把$max作为数组的另一端,而不是字符串的一部分?
当前回答
这是一种方式: Bash:
max=10
for i in $(bash -c "echo {2..${max}}"); do echo $i; done
当Bash -c分别被ksh -c或zsh -c取代时,上述Bash方式也适用于ksh和zsh。
注:对于i在{2..${max}};执行echo $i;在ZSH和ksh中做功。
其他回答
手动踩环:
i=0 max=10 while [ $i -lt $max ] do echo "output: $i" true $(( i++ )) done
如果你不需要完全POSIX,你可以使用算术for循环:
max=10 for (( i=0; i < max; i++ )); do echo "output: $i"; done
或者在BSD系统上使用jot(1):
for i in $( jot 0 10 ); do echo "output: $i"; done
这些都做{1..8},并且都应该是POSIX。他们也不会打破如果你 在循环中放入一个条件continue。规范的方式:
f=
while [ $((f+=1)) -le 8 ]
do
echo $f
done
另一种方法:
g=
while
g=${g}1
[ ${#g} -le 8 ]
do
echo ${#g}
done
另一个:
set --
while
set $* .
[ ${#} -le 8 ]
do
echo ${#}
done
如果seq命令在您的系统上可用:
for i in `seq 2 $max`
do
echo "output: $i"
done
如果不是,那么在perl中使用poor man's seq:
seq=`perl -e "\$,=' ';print 2..$max"`
for i in $seq
do
echo "output: $i"
done
注意那些引号。
这是一种方式: Bash:
max=10
for i in $(bash -c "echo {2..${max}}"); do echo $i; done
当Bash -c分别被ksh -c或zsh -c取代时,上述Bash方式也适用于ksh和zsh。
注:对于i在{2..${max}};执行echo $i;在ZSH和ksh中做功。
有不止一种方法。
max=10
for i in `eval "echo {2..$max}"`
do
echo "$i"
done