在我的脚本中,我从另一个变量mflow计算变量folder。计算必须以高精度进行,但最终结果必须截断为一个有效数字。目前我正在做这个:
#!/bin/bash
for folder in 100 115 116 117; do
temp=$(bc <<< "scale=20;$folder/100*14.8")
mflow=$(bc <<< "scale=1;$temp*1/1")
echo $mflow
done
exit 0效果很好。然而,行
mflow=$(bc <<< "scale=1;$temp*1/1")好像有点浪费。是否有一种方法可以以高精度执行中间计算,并以所选的(较低)精度将结果分配给mflow?当然,我不想牺牲脚本的可读性。因此,请不要像那些sed“地狱中的单行者”那样的解决方案(好吧,我想sed不能用于这个问题,但你明白我的意思)。
万一有人想知道我为什么不直接写
mflow=$(bc <<< "scale=1;$folder/100*14.8")只需尝试脚本中的修改,看看会发生什么( mflow的最后三个值变得相等,这会在脚本工作流中产生问题)。
发布于 2016-05-19 13:42:11
您可以使用awk进行计算和输出格式设置:
for folder in 100 115 116 117; do
awk -v f="$folder" 'BEGIN{printf "%.1f\n", f/100*14.8}'
done因此,它规定:
14.8
17.0
17.2
17.3如果希望打印更精确的结果,可以将%.1f更改为%.20f,然后有:
14.80000000000000071054
17.01999999999999957367
17.16799999999999926104
17.31599999999999894840注意:
如果您选择了bc,您应该知道这个“特性”:
kent$ echo "scale=1;17.17777/1"|bc
17.1它将给您提供17.1而不是17.2。我希望在选择bc作为您的工具之前,您已经知道了这一点。
https://stackoverflow.com/questions/37324387
复制相似问题