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函数来获取这些?
答案 0 :(得分:7)
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)