Warning: file_get_contents(/data/phpspider/zhask/data//catemap/1/php/231.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Apache pig 清管器四舍五入至小数点后第n位_Apache Pig_Rounding - Fatal编程技术网

Apache pig 清管器四舍五入至小数点后第n位

Apache pig 清管器四舍五入至小数点后第n位,apache-pig,rounding,Apache Pig,Rounding,如何将浮点或双精度整数舍入到pig中的小数点后第n位。比如说 f(3.999999, 1) = 3.9 f(3.42317, 2) = 3.42 f(1.03, 1) = 1.0 我真的只需要四舍五入到小数点后的第一位,但我想我会把这个问题留给大家。我看到了“猪的小数点后四舍五入到两位”的问题,但答案并没有解释到我能适应这个问题的程度。谢谢 答复 事实证明,数学很容易解决这个问题。只要做: FLOOR(column * 10^n) / 10^n 猪有。这将根据所需的小数点进行四舍五入 B

如何将浮点或双精度整数舍入到pig中的小数点后第n位。比如说

f(3.999999, 1) =  3.9
f(3.42317, 2) = 3.42
f(1.03, 1) = 1.0
我真的只需要四舍五入到小数点后的第一位,但我想我会把这个问题留给大家。我看到了“猪的小数点后四舍五入到两位”的问题,但答案并没有解释到我能适应这个问题的程度。谢谢


答复 事实证明,数学很容易解决这个问题。只要做:

FLOOR(column * 10^n) / 10^n
猪有。这将根据所需的小数点进行四舍五入

B = FOREACH A GENERATE ROUND_TO(input,num_of_decimal_places);
例如:

输入文件:

3.999999
3.42317
1.03
A=加载“文件”为(num:float); B=为每个A生成一个舍入(num,2); 垃圾场B

输出:

(4.0)
(3.42)
(1.03)
仅供参考。“常见的技巧(1000.0*ROUND(x/1000))不仅难以理解,而且无法产生精确的数值结果”