当前位置:  开发笔记 > 编程语言 > 正文

如何在应用agg函数之前将十进制值限制为2位数?

如何解决《如何在应用agg函数之前将十进制值限制为2位数?》经验,为你挑选了1个好方法。

我正在从堆栈溢出帖子中找到这个解决方案,我唯一的要求是如何在应用df.agg(sum())函数之前将我想要求和的值限制为小数点后的2位数?

例如:我有如下的值,sum函数对它进行求和,

2.346
1.549

但是我希望将值舍入为小数点后的2位数

2.35
1.55

在总结之前.我该怎么做?我无法找到任何功能的子sum().round功能sum.

注意:我使用的是Spark 1.5.1版本.



1> Psidom..:

你可以使用bround:

val df = Seq(2.346, 1.549).toDF("A")
df.select(bround(df("A"), 2)).show
+------------+
|bround(A, 2)|
+------------+
|        2.35|
|        1.55|
+------------+


df.agg(sum(bround(df("A"), 2)).as("appSum")).show
+------------------+
|            appSum|
+------------------+
|3.9000000000000004|
+------------------+
                                          ^
df.agg(sum(df("A")).as("exactSum")).show
+--------+
|exactSum|
+--------+
|   3.895|
+--------+

推荐阅读
ar_wen2402851455
这个屌丝很懒,什么也没留下!
DevBox开发工具箱 | 专业的在线开发工具网站    京公网安备 11010802040832号  |  京ICP备19059560号-6
Copyright © 1998 - 2020 DevBox.CN. All Rights Reserved devBox.cn 开发工具箱 版权所有