List((1070071808,"NA",1077477376), (1070071808,aggr1,1077477376),
(1070071808,aggr1,1077477376), (1070071808,aggr1,1077477376),
(1070071808,aggr1,1077477376), (1070071808,aggr1,1077477376),
(1070071808,aggr1,1077477376), (1070071808,aggr1,1077477376))
如果第二个元素不是“ NA”,我想添加usedBytes。我的预期输出是
usedSpace =所有列表元素中第一个值不等于“ NA”的第一个值的总和
freeSpace =如果第二个值为“ NA”,则列表中的第一个值之和。
如何通过使用惯用的scala函数获取这些信息?
val list = List((1070071808, "NA", 1077477376), (1070071808, "aggr1", 1077477376),
(1070071808, "aggr1", 1077477376), (1070071808, "aggr1", 1077477376),
(1070071808, "aggr1", 1077477376), (1070071808, "aggr1", 1077477376),
(1070071808, "aggr1", 1077477376), (1070071808, "aggr1", 1077477376))
val (free, used) = list.partition(_._2 == "NA")
val freeSpace = free.foldLeft(0L)(_ + _._1) // uses Long to avoid overflow
val usedSpace = used.foldLeft(0L)(_ + _._1)
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句