답변:
빼기 부호 주위에 약간의 공백과 백틱이 필요합니다.
COUNT=`expr $FIRSTV - $SECONDV`
종료 상태에 유의하십시오.
EXPRESSION이 널 또는 0 이 아닌 경우 종료 상태는 0이고 EXPRESSION이 널 또는 0이면 1 입니다.
명령이 0이 아닌 상태로 종료되면 즉시 종료되는 set -e 와 함께 bash 스크립트에서 표현식을 사용할 때이 점을 명심하십시오 .
sh
쉘 에서도 작동합니다 . 이식성을 위해이 답변을 사용할 수 있습니다.
외부 프로그램을 사용하는 대신이 Bash 구문을 사용해보십시오 expr
.
count=$((FIRSTV-SECONDV))
BTW에서 사용하는 올바른 구문 expr
은 다음과 같습니다.
count=$(expr $FIRSTV - $SECONDV)
그러나 expr
위에서 제공 한 내부 Bash 구문보다 사용 속도가 느려집니다.
$(command)
명령 대체를위한 새로운 구문을 지원합니다 . 또한 BASH는 산술 연산을 지원 $(( ... ))
하기 때문에 외부 유틸리티를 사용하지 않는 것이 좋습니다expr
$(( ... ))
산술 연산 식을 평가하는 데 사용됩니다.
이것이 항상 Bash에서 수학을 수행하는 방법입니다.
count=$(echo "$FIRSTV - $SECONDV"|bc)
echo $count
|bc
한 번 또는 두 번 놓치는 것보다 유형 명령으로 그러한 경우를 잡는 습관을 만들고 싶습니다 . 그들이 말하는 것처럼 다른 사람들을 위해 다른 뇌졸중.
간단한 정수 산술을 위해 내장 let 명령을 사용할 수도 있습니다 .
ONE=1
TWO=2
let "THREE = $ONE + $TWO"
echo $THREE
3
let "sanity_check_duration=sanity_check_duration_end_time_delay_sec - sanity_check_duration_start_time_delay_sec"
(변수에서 제거 달러 기호)
제안 된 3 가지 방법 대신 let
다음과 같이 변수에 대한 산술 연산을 수행 할 수 있습니다 .
let COUNT=$FIRSTV-$SECONDV
또는
let COUNT=FIRSTV-SECONDV
파이썬 사용 :
#!/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
$