24

如何使用截断浮点数bc

例如,如果我这样做

echo '4.2-1.3' | bc

它输出2.9我如何让​​它截断/使用 floor 来获取2

4

4 回答 4

26

使用/运算符。

echo '(4.2-1.3) / 1' | bc
于 2013-12-13T03:46:42.307 回答
16

scale如果为 0,除以 1 可以正常工作(例如,如果您从 bc 开始bc并且不更改scale),但如果scale是正数(例如,如果您从 bc 开始bc -l或增加scale)则失败。(请参阅下面的文字记录。)对于一般解决方案,请使用trunc如下函数:
define trunc(x) { auto s; s=scale; scale=0; x=x/1; scale=s; return x }

说明在这种情况下除以 1 本身如何失败的成绩单bc -l,但trunc函数如何在向零截断时正常工作:

> bc -l
bc 1.06.95
[etc...]
for (x=-4; x<4; x+=l(2)) { print x,"\t",x/1,"\n"}
-4  -4.00000000000000000000
-3.30685281944005469059 -3.30685281944005469059
-2.61370563888010938118 -2.61370563888010938118
-1.92055845832016407177 -1.92055845832016407177
-1.22741127776021876236 -1.22741127776021876236
-.53426409720027345295  -.53426409720027345295
.15888308335967185646   .15888308335967185646
.85203026391961716587   .85203026391961716587
1.54517744447956247528  1.54517744447956247528
2.23832462503950778469  2.23832462503950778469
2.93147180559945309410  2.93147180559945309410
3.62461898615939840351  3.62461898615939840351
define trunc(x) { auto s; s=scale; scale=0; x=x/1; scale=s; return x }
for (x=-4; x<4; x+=l(2)) { print x,"\t",trunc(x),"\n"}
-4  -4
-3.30685281944005469059 -3
-2.61370563888010938118 -2
-1.92055845832016407177 -1
-1.22741127776021876236 -1
-.53426409720027345295  0
.15888308335967185646   0
.85203026391961716587   0
1.54517744447956247528  1
2.23832462503950778469  2
2.93147180559945309410  2
3.62461898615939840351  3
于 2013-12-13T08:42:29.567 回答
7

尝试以下解决方案。它会毫无问题地截断小数点后的任何内容:

echo 'x = 4.2 - 1.3; scale = 0; x / 1' | bc -l
echo 'x = l(101) / l(10); scale = 0; x / 1' | bc -l

您可以通过直接对数字执行计算来使代码更短:

echo 'scale = 0; (4.2 - 1.3) / 1' | bc -l
echo 'scale = 0; (l(101) / l(10)) / 1' | bc -l

通常,您可以使用此函数仅获取数字的整数部分:

define int(x) {
    auto s;
    s = scale;
    scale = 0;
    x /= 1; /* This will have the effect of truncating x to its integer value */
    scale = s;
    return (x);
}

将该代码保存到文件中(我们称之为int.bc)并运行以下命令:

echo 'int(4.2 - 1.3);' | bc -l int.bc
于 2018-11-29T04:58:00.033 回答
1

控制除法小数位数的变量是scale

因此,如果 scale 是0(默认值),除以 1 将截断为0小数:

$ echo '(4.2-1.3) / 1 ' | bc
2

在其他操作中,小数位数是根据每个操作数的比例(小数位数)计算的。例如,在加法、减法和乘法中,得到的比例是两者中最大的:

$ echo ' 4.2 - 1.33333333 ' | bc
2.86666667

$ echo ' 4.2 - 1.333333333333333333 ' | bc
2.866666666666666667

$ echo ' 4.2000 * 1.33 ' | bc
5.5860

相反,在除法中,小数位数严格等于变量 的值scale

$ echo 'scale=0;4/3;scale=3;4/3;scale=10;4/3' | bc
1
1.333
1.3333333333

由于必须恢复 scale 的值,因此最好定义一个函数(GNU 语法):

$ echo ' define int(x){ os=scale;scale=0;x=x/1;scale=os;return(x) } 
         int( 4.2-1.3 )' | bc
2

或使用较旧的 POSIX 语言:

$ echo ' define i(x){
             o=scale;scale=0;x=x/1;scale=o;return(x)
         } 
         i( 4.2-1.3 )' | bc
2
于 2020-04-27T21:45:55.580 回答