首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >在脚本中,以高精度计算浮点,并以较低的精度存储在shell变量值中。

在脚本中,以高精度计算浮点,并以较低的精度存储在shell变量值中。
EN

Stack Overflow用户
提问于 2016-05-19 13:17:03
回答 1查看 60关注 0票数 1

在我的脚本中,我从另一个变量mflow计算变量folder。计算必须以高精度进行,但最终结果必须截断为一个有效数字。目前我正在做这个:

代码语言:javascript
复制
#!/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

效果很好。然而,行

代码语言:javascript
复制
mflow=$(bc <<< "scale=1;$temp*1/1")

好像有点浪费。是否有一种方法可以以高精度执行中间计算,并以所选的(较低)精度将结果分配给mflow?当然,我不想牺牲脚本的可读性。因此,请不要像那些sed“地狱中的单行者”那样的解决方案(好吧,我想sed不能用于这个问题,但你明白我的意思)。

万一有人想知道我为什么不直接写

代码语言:javascript
复制
mflow=$(bc <<< "scale=1;$folder/100*14.8")

只需尝试脚本中的修改,看看会发生什么( mflow的最后三个值变得相等,这会在脚本工作流中产生问题)。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2016-05-19 13:42:11

您可以使用awk进行计算和输出格式设置:

代码语言:javascript
复制
for folder in 100 115 116 117; do
        awk -v f="$folder" 'BEGIN{printf "%.1f\n", f/100*14.8}'
done

因此,它规定:

代码语言:javascript
复制
14.8
17.0
17.2
17.3

如果希望打印更精确的结果,可以将%.1f更改为%.20f,然后有:

代码语言:javascript
复制
14.80000000000000071054
17.01999999999999957367
17.16799999999999926104
17.31599999999999894840

注意:

如果您选择了bc,您应该知道这个“特性”:

代码语言:javascript
复制
kent$  echo "scale=1;17.17777/1"|bc  
17.1

它将给您提供17.1而不是17.2。我希望在选择bc作为您的工具之前,您已经知道了这一点。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/37324387

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档