我已经尝试使用两者递增一个数字变量 var=$var+1
和 var=($var+1)
没有成功。 变量是一个数字,尽管bash似乎将其作为字符串读取。
Bash版本4.2.45(1)-在Ubuntu13.10上发布(x86_64-pc-linux-gnu)。
我已经尝试使用两者递增一个数字变量 var=$var+1
和 var=($var+1)
没有成功。 变量是一个数字,尽管bash似乎将其作为字符串读取。
Bash版本4.2.45(1)-在Ubuntu13.10上发布(x86_64-pc-linux-gnu)。
在bash中递增变量的方法不止一种,但是你尝试的是不正确的。
您可以使用例如 算术扩展:
var=$((var+1))((var=var+1))((var+=1))((var++))
或者你可以使用 let
:
let "var=var+1"let "var+=1"let "var++"
var=$((var + 1))
Bash中的算术使用 $((...))
语法。
感谢 Radu Rīdeanu的回答 这提供了以下方法来增加bash中的变量:
var=$((var+1))((var=var+1))((var+=1))((var++))let "var=var+1"let "var+=1" let "var++"
还有其他方法。 例如,看看这个问题的其他答案。
let var++var=$((var++))((++var)){ declare -i var var=var+1 var+=1}{ i=0 i=$(expr $i + 1)}
有这么多选择导致这两个问题:
#!/bin/bash# To focus exclusively on the performance of each type of increment# statement, we should exclude bash performing while loops from the# performance measure. So, let's time individual scripts that# increment $i in their own unique way.# Declare i as an integer for tests 12 and 13.echo > t12 'declare -i i; i=i+1'echo > t13 'declare -i i; i+=1'# Set i for test 14.echo > t14 'i=0; i=$(expr $i + 1)'x=100000while ((x--)); do echo >> t0 'i=$((i+1))' echo >> t1 'i=$((i++))' echo >> t2 '((i=i+1))' echo >> t3 '((i+=1))' echo >> t4 '((i++))' echo >> t5 '((++i))' echo >> t6 'let "i=i+1"' echo >> t7 'let "i+=1"' echo >> t8 'let "i++"' echo >> t9 'let i=i+1' echo >> t10 'let i+=1' echo >> t11 'let i++' echo >> t12 'i=i+1' echo >> t13 'i+=1' echo >> t14 'i=$(expr $i + 1)'donefor script in t0 t1 t2 t3 t4 t5 t6 t7 t8 t9 t10 t11 t12 t13 t14; do line1="$(head -1 "$script")" printf "%-24s" "$line1" { time bash "$script"; } |& grep user # Since stderr is being piped to grep above, this will confirm # there are no errors from running the command: eval "$line1" rm "$script"done
i=$((i+1)) user 0m0.992si=$((i++)) user 0m0.964s((i=i+1)) user 0m0.760s((i+=1)) user 0m0.700s((i++)) user 0m0.644s((++i)) user 0m0.556slet "i=i+1" user 0m1.116slet "i+=1" user 0m1.100slet "i++" user 0m1.008slet i=i+1 user 0m0.952slet i+=1 user 0m1.040slet i++ user 0m0.820sdeclare -i i; i=i+1 user 0m0.528sdeclare -i i; i+=1 user 0m0.492si=0; i=$(expr $i + 1) user 0m5.464s
看来bash的表现最快 i+=1
何时 $i
被声明为整数。 let
陈述似乎特别缓慢,并且 expr
是迄今为止最慢的,因为它不是一个内置到bash。
还有这个:
var=`expr $var + 1`
注意空格,也要注意 ` 不是 '
虽然Radu的答案和评论是详尽且非常有帮助的,但它们是bash特定的。 我知道你确实特别问过bash,但是当我在uclinux下的busybox中使用sh时,我想我会插话,因为我发现了这个问题。 这种便携式超越bash。
如果你声明 $var
作为一个整数,那么你第一次尝试的东西实际上会起作用:
$ declare -i var=5$ echo $var5$ var=$var+1$ echo $var6
参考资料: 变量的类型,初学者的Bash指南
所有答案中都缺少一种方法 - bc
$ VAR=7 $ bc <<< "$VAR+2"9$ echo $VAR7$ VAR=$( bc <<< "$VAR+1" )$ echo $VAR8
bc
由 N.POSIX 标准,所以应该出现在所有版本的Ubuntu和POSIX兼容系统. 该 <<<
重定向可以更改为 echo "$VAR" | bc
对于可移植性,但由于问题问 bash
-这是确定的只是使用 <<<
.
返回代码 1
所有默认变体都存在问题(let
, (())
等。). 这通常会导致麻烦,例如,在使用 set -o errexit
. 以下是我用于防止错误代码的内容 1
从计算的数学表达式到 0
;
math() { (( "$@" )) || true; }math a = 10, b = 10math a++, b+=2math c = a + bmath mod = c % 20echo $a $b $c $mod#11 12 23 3
这必须是完成这样一个简单任务的最糟糕的方式,但我只是想记录它的乐趣,我想(完全相反的代码高尔夫)。
$ var=0$ echo $var0$ var="$(python -c 'print('$var'+1)')"$ echo $var1
或
$ var="$(printf '%s\n' $var'+1' | bc)"$ echo $var1
认真使用其他更好的选择之一。
这是安全的赌注
(( var = var + 1 ))
如果结果值非零,则设置exit on error将停止脚本
set -evar=0(( var++ ))echo You will never get here