如果使用scala不存在键,如何分隔列表元素?

时间:2014-11-08 08:04:41

标签: list scala

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函数来获取这些?

1 个答案:

答案 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)