Apache pig 清管器四舍五入至小数点后第n位
如何将浮点或双精度整数舍入到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
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))不仅难以理解,而且无法产生精确的数值结果”