Answers:
您只需要在减号和反引号周围留一些多余的空格:
COUNT=`expr $FIRSTV - $SECONDV`
注意退出状态:
如果EXPRESSION既不为null也不为0,则退出状态为0;如果EXPRESSION为null或0,则退出状态为1。
在bash脚本中将表达式与set -e结合使用时,请记住这一点,如果命令以非零状态退出,则该表达式将立即退出。
sh
shell中使用。为了便于携带,您可能需要使用此答案。
尝试使用以下Bash语法,而不是尝试使用外部程序expr
:
count=$((FIRSTV-SECONDV))
顺便说一句,using的正确语法expr
是:
count=$(expr $FIRSTV - $SECONDV)
但是请记住,使用expr
它的速度将比我上面提供的内部Bash语法慢。
$(command)
的命令替换语法。另外,由于BASH支持算术运算,$(( ... ))
因此最好不要使用外部实用程序expr
$(( ... ))
用于评估算术表达式。
空格很重要,expr
它的操作数和运算符应作为单独的参数。您还必须捕获输出。像这样:
COUNT=$(expr $FIRSTV - $SECONDV)
但是更常见的是使用内置的算术扩展:
COUNT=$((FIRSTV - SECONDV))
这就是我一直在Bash中做数学的方式:
count=$(echo "$FIRSTV - $SECONDV"|bc)
echo $count
|bc
类型命令来捕获这些情况的习惯,而不是一两次错过它。正如他们所说,针对不同人的不同笔触。
let "sanity_check_duration=sanity_check_duration_end_time_delay_sec - sanity_check_duration_start_time_delay_sec"
(从变量中删除了美元符号)
使用Python:
#!/bin/bash
# home/victoria/test.sh
START=$(date +"%s") ## seconds since Epoch
for i in $(seq 1 10)
do
sleep 1.5
END=$(date +"%s") ## integer
TIME=$((END - START)) ## integer
AVG_TIME=$(python -c "print(float($TIME/$i))") ## int to float
printf 'i: %i | elapsed time: %0.1f sec | avg. time: %0.3f\n' $i $TIME $AVG_TIME
((i++)) ## increment $i
done
输出量
$ ./test.sh
i: 1 | elapsed time: 1.0 sec | avg. time: 1.000
i: 2 | elapsed time: 3.0 sec | avg. time: 1.500
i: 3 | elapsed time: 5.0 sec | avg. time: 1.667
i: 4 | elapsed time: 6.0 sec | avg. time: 1.500
i: 5 | elapsed time: 8.0 sec | avg. time: 1.600
i: 6 | elapsed time: 9.0 sec | avg. time: 1.500
i: 7 | elapsed time: 11.0 sec | avg. time: 1.571
i: 8 | elapsed time: 12.0 sec | avg. time: 1.500
i: 9 | elapsed time: 14.0 sec | avg. time: 1.556
i: 10 | elapsed time: 15.0 sec | avg. time: 1.500
$